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ABSTRACT 


The engineering methodology for producing a fully tested VLSI chip from a design 
layout 1s presented. A 16-bit correlator, NPS CORNSS, that was previously designed, 
was used as a vehicle to to demonstrate this methodology. The study of the design and 
simulation tools, MAGIC and MOSSIM II, was the focus of the design and validation 
process. The design was then implemented and the chip was fabricated by MOSIS. 

This fabricated chip was then used to develop a testing methodology for using the 
digital test facilities at NPS. NPS CORNSS was the first full custom VLSI chip, de- 
signed at NPS. to be tested with the NPS digital analysis system, Tektronix DAS 9100 
series tester. The capabilities and limitations of these test facilities are examined within 
this thesis. NPS CORNSS test results are included to demonstrate the capabilities of the 
digital test system. A translator, MOS2DAS, was developed to convert the MOSSIM 
I] simulation program to the input files required bv the DAS 9100 device verification 
software, 9IDVS. Finally, a tutorial for using the digital test facilities, including the 


DAS 9100 and associated support equipments, 1s included as an appendix. 
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I. INTRODUCTION 


A. BACKGROUND 

“For the past 20 vears chip complexity and thus the functional capability of a single 
integrated circuit (IC) have roughly doubled every year.” [Ref. l,p. 1]. Chip development 
has progressed from the small scale integration (SSI) to that of the very large scale in- 
tegrated (VLSI) circuit. Current technology considers a VLSI chip to contain more than 
100,000 gates and transistors. As advances have been made in the manufacturing process 
and composition materials, the chip density has become greater and the chips operate 
at a faster rate. This growth in more devices per unit area and complexity of VLSI cir- 
cuits has required that the testing and validation process of these chips become more 
sophisticated. fost custom VLSI chips that are developed are produced for a specific 
purpose and are referred to as application specific integrated circuits (ASICs). For each 
of these full custom chips a methodology must be used to implement and validate the 
design, functionally test the completed cell before manufacture, and comprehensive 
testing of the VLSI chip after it returns from the manufacture’s foundry. Again, due to 
the complexity of the circuits this methodology is often driven by the computer tools 
that are available to assist the circuit designer and test engineer. Computer-aided design 
(CAD) computer-aided testing (CAT) and computer simulation routines have become 
essential in the development of high performance VLSI chips. 

CAD programs assist the VLSI chip designer in the physical layout of the design 
circuitry. These CAD programs help isolate the designer from the masking details. al- 
lowing the design effort to concentrate on higher level development. [Illustrating the 
explosion of interest in the area of CAD development, a recent Computer Design issue 
[Ref. 2], listed over 29 commercial vendors with 53 different models of printed circuit 
board CAD systems. The printed circuit board based CAD system uses a combination 
of specially designed hardware and software to layout the design. At the Naval Post- 
graduate School (NPS), the CAD layout tools of MAGIC and GENESIL are imple- 
mented in software. 

MAGIC, developed at the Universitv of California at Berkeley, is a research soft- 
ware tool that is installed on the Digital Vax 780/1185 and three Integrated Solutions 
Incorporated (ISI) work stations. It provides the circuit designer with an interactive 


lavout editing svstem for large-scale MOS custom integrated circuits and is discussed in 


detail in [Ref. 3]. It allows the designer to engage in full custom VLSI design from the 
transistor to the librarv cell level. Knowledge of silicon semiconductor technology is 
required for various forms of transistor development but designs at the gate level and 
higher are possible bv using hbrarv cells that have already been designed. Once the cells 
have been developed, or recalled from the cell library, MAGIC can assemble them hi- 
erarchicallv into the required circuitry. It also provides a powerful router to establish the 
connectivity between cells. One of the key advantages of using MAGIC 1s the feature 
that is provided called design-rule checking. MAGIC maintains a continuous design-rule 
check to ensure that the proper topology and layout parameters are maintained for the 
technology (CMOS,NMOS, PMOS) as well as the technology required by the foundry. 
This design-rule check is updated incrementallv during the design and if an error occurs 
then that area of concern is highlighted by white dots. Magic does not offer any timing 
or fault isolation simulation, but the MAGIC design file can be extracted and several 
simulation tools can then be run to validate the design. 

“The GENESIL Silicon Development System is a comprehensive turnkey desiam 
automation system for creation of integrated circuits, NMOS or CMOS.” [Ref. 4]. 
GENESIL is a commercial CAD tool from Silicon Compiler Systems that also runs on 
the VAX with an interface either a schematic capture graphics display terminal or from 
its own graphics terminal. The user manual for the svstem [Ref. 4] stresses that the goal 
of GENESIL is to make IC design approachable to svstems designers who lack IC de- 
Signer expertise. To that end GENESIL is a menu driven interactive layout editing 
system that concentrates on high-level systems design. There are hundreds of complex 
functional parts available in its library of cells. and the designer selects the cells from 
which to build and connects them together with the netlist of routing commands. 

It is important to stress the difference between this method of assembling cells in 
GENESIL contrasted to that of the MAGIC CAD tools. The GE NES sx stempares 
signer does not view or build the library cells below the gate level. No knowledge of 
silicon semiconductor technology is required by the designer and there is no reason for 
GENESIL to provide for design-rule checking because the library cells have alreadv met 
all design performance criteria. GENESIL also provides a design verification package 
as part of its software package. Timing analysis, power requirement analysis, and au- 
tomatic test generation allow the designer to functionally verify that the chip design is 
sound. This is done entirely within the GENESIL svstem without interfacing with other 
simulation software. This definitely speeds up the design and verification process of the 


custom VLSI chip considerably. Decreasing the development time of the VLSI chip en- 


to 


courages the designer to experiment and optimize the circuit design. Once the design 1s 
set and verified, GENESIL can translate the design to the geometric masking data used 
by several different manufacturing foundries. From design concept to fabrication tool- 
ing, GENESIL produces high performance custom ASIC designs. Three NPS graduate 
thesis illustrate the robust features of the GENESIL silicon compiler. Settle examined 
the design methodology of using the GENESIL silicon compiler by designing a pipeline 
16-bit multiplier [Ref. 5]. Rocky implemented a Kalman Filter Algorithm as an ASIC 
on GENESIL [Ref. 6]. Davidson examined testability strategy using GENESIL’s fea- 
tures on Automatic Test Generation (ATG) and the test latch librarv cell [Ref. 7]. Re- 
Viewing these thesis will provide a solid foundation for utilizing the GENESIL silicon 
compiler. 

MAGIC is the CAD tool used bv NPS students enrolled in VLSI course work and 
was used for the development of NPS CORNS8$8 during this thesis research. It stresses 
silicon semiconductor technology and provides a greater insight into masking design and 
lavout rules. But, verifving a MAGIC design requires that the circuit must be extracted 
into a format that a computer simulation model will utilize. The three electrical circuit 
simulation models that are widely used at NPS are MOSSIM II, SPICE, and Register 
Notational Language (RNL). 

MOSSIM II is a logic simulator based on the switch-level logic model. It models a 
MOS digital circuit as a network of nodes connected by transistor switches and can ac- 
curately model such circuit structures as bi-directional pass transistors, ratioed and 
complementary logic buses, dynamic memorv and charge sharing. MOSSIM II, de- 
scribed in detail in the user’s manual [Ref. § ], is designed primarily for simulating 
clocked svstems where a clocking scheme consists of a set of state sequences to be ap- 
plied cyclically to a set of nodes. Identifving the input forcing vectors and the outputs 
to be watched, MOSSIM II will run the modeled circuit and produce the simulated 
Output results at each clock cycle identified. Although MOSSIM II provides minimum 
timing information, it can identifv potential timing errors. Because MOSSIM II is based 
on a switch-level model, it can handle large-scale sequential and combinational logic 
design projects relatively quickly, but it can not be used on analog designs. 

Another digital circuit simulator, RNL, is a timing simulator for digital MOS cir- 
cuits. It is an event-driven simulator that uses a simple resistance and capacitance (RC) 
model of the circuit to estimate node transistor time and to estimate the effects of charge 
sharing. RNL provides similar features to MOSSIM II which are outlined in the RNL 


user manual [Ref. 9]. The user interface for the RNL simulation program is a version 


of LISP. RNL appears to run as fast as MOSSIM II but it can not handle bi-directional 
pass transistors. It also can only be used to simulate digital circuitry and can not be used 
on analog circuitry. 

SPICE simulation is based on the numerical solution of the network’s differential 
equations. After the MAGIC file is extracted, each transistor, resistor, and capacitor 1s 
modeled. Detailed instructions on using SPICE are included 1n users guide [Ref. 10] and 
are applicable for analog and digital circuits. It 1s important to note that because SPICE 
computes the differential equation for each transistor it 1s very slow and 1s practical for 
only small circuits or in validating library cells. It does produce superior simulation 
timing results, electrical parameters at all observed nodes, and statistical features that 
allow the designer to examine in detail the complete operation of the circuit. For that 
reason SPICE 1s valuable in validating individual leaf cells, but is seldom used on the 
entire VLSI digital designs. 

Once the final design has been functionally validated 1t must be packaged for the 
manufacturing foundry. MOSIS 1s an a acronym for MOS Implementation System and 
acts as a clearing house facility to handle the details in manufacturing a chip. Coordi- 
nated from the Information Sciences Institute of the University of Southern California 
MIOSIS ensures that the chip has correct syntax upon receipt of the lavout geometry and 
delivers a set of bonded and packaged chips to the user. This can be done at a very 
reasonable cost because several different designs of the same silicon technology share the 
same silicon wafer. The complete process from submitting the VLSI chip lavout to the 
delivery by MOSIS of the fabricated chip is outlined in the users manual [Ref. 11 ]. 

Once the VLSI chip has been manufactured and returned to NPS, the Tektronix 
DAS 9100 series tester is used to test the fabricated chip. This stand-alone, digital anal- 
ysis svstem can functionally verify that the VLSI chip meets the required performance 
standards for various operational speeds. The user manual for the Tektronix DAS 9100 
Series tester [Ref. 12] details the pattern generation and data acquisition features. The 
DAS 9100 tester at NPS can also link to a personal computer (PC) and device verifica- 
tion software (DVS). This configuration generates test patterns in vector format and 
configures the Tektronix DAS 9100 tester to the device under test (DUT). 

When designing a custom ASIC, it is extremely important for the design engineer 
to take into consideration and understand all the tools that are available. The testing and 
testability of a VLSI circuit must be considered in every phase of the chip development, 
from the conceptual design phase of the circuit to the final functional validation of the 
manufactured VLSI chip. 


B. THESIS GOALS 

This thesis will examine the methodology used to produce a VLSI chip from initia! 
design to final validation of the manufactured VLSI chip, concentrating on the testing 
and testability issues. The development of a 16-bit correlator, NPS CORNS8, will be 
followed throughout the phases to illustrate the process methodology. 

Another goal of the thesis is the development of a program that will translate the 
results of a Mossim IT simulation program to that suitable for use in the Tektronix DAS 
9100 series tester. An introduction for the new user to the Tektronix hardware test 
equipment, and associated software features, will also be presented. A tutorial for the 


digital test facilities at NPS is presented as Appendix A. 


C. THESIS ORGANIZATION 

Chapter II provides the methodology for taking a design from the conceptual phase 
to the completion of the VLSI chip. This will include: a functional overview of NPS 
CORNSS, its design implementation in Magic, follow on simulation with the MOSSIM 
I] simulator, and subsequent manufacturing by MOSIS. Chapter III] will concentrate 
on the TEKTRONIX DAS 9100 series tester and its operational capabilities. The test 
results of the manufactured VLSI chip. NPS CORNS$88, will also be examined and inter- 
fPeecea in this chapter. Chapter IV will present the development of the MOS2DAS 
translator and other support software. Chapter V summarizes the salient features of the 
thesis and offers recommendations for improving VLSI chip testing at the Naval Post- 
graduate School. Suggestions for future research are also presented. Appendix A con- 
Pimgeed tutorial for the TERK TRONIN DAS 9100 series tester and the NPS digital test 
facilities. Appendix B contains the Fortran source program for the MOS2DAS translator 
and supporting programs. Appendix C contains the source programs necessary for 


generating multiple 16-bit MOSSIM II test vectors and calculating the expected results. 


II. DESIGN IMPLEMENTATION 


How does a VLSI chip designer advance from the design phase, through the devel- 
opmental stage, to having the chip manufactured, using the facilities at NPS? What 
methodology is considered at each of the major phases in this process? Figure 1 on page 
7 illustrates this processing flow from design to receipt of the manufactured VLSI chip. 
This chapter provides an overview of each of the major phases involved in the develop- 
ment process. Discussion of each of these phases is augmented bv following the devel- 
opment of a 16-bit correlator, NPS CORNS8. Examples are provided to highlight the 
methodology and salient features at each development phase. Testability issues at each 
phase will be addressed within that phase. The understanding of each phase of devel- 


opment Will allow for a smooth transition between phases. 


A. NPS CORN88 
1. Initial Design Methodology 

A correlator takes a binary string from a data source and compares that string 
with a reference binary string. The results of this are either an exact correlation, where 
each digit of the data string matches that of a reference string, or some subset of that 
exact correlation. Because of the many and varied applications that can be performed 
by a correlator, NPS CORNSS was designed to be as general as possible and produces 
the number of string matches as a binary coded decimal (BCD) output. 

The initial iteration of this design effort [Ref. 13] was accomplished by Beck and 
Galinas, students at NPS. They produced a functional, stand-alone, working prototype 
of a correlator at the Magic architecture level. An additional design team composed of 
Walt Corliss. Michael Roderick. Yong Ha Ko, and David Carleton, led by Professor 
Chyan Yang, optimized the lavout of the design, added the pad frame and associated 
routing, conducted additional testing, and submitted the finished design effort to MOSIS 
for manufacturing. 

Throughout this second design iteration the concerns of testability and testing 
were addressed. Each individual cell (D flip flop, 2-1 multiplexer, full four bit adder, etc.) 
of the optimized design was functionally tested using the MOSSIM II and SPICE sim- 
ulators. After these cells were assembled into the correlator, as illustrated in Figure 2 
on page 9 by a Coordinate Free Lap (CFL) program, the completed design was divided 


into two sections for further testing, the sequential and combinational logic sections. 
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After successfully testing each of these sections the entire design was tested by forcing 
every possible 16-bit data string combination available onto the parallel input pins. 
Because of the large number of 16-bit vectors that had to be generated, a C language 
program was written to generate 65,536 (2'%) different vectors. Another program was 
Written to calculate the output for each input vector. A C-Shell program was used to run 
the MOSSIM II simulation with this exhaustive list of vectors and compare the 
correlator outputs to that of the calculated outputs. The source code for these programs 
are listed in Appendix C. After the successful completion of this exhaustive test, the 
design and simulation program were considered validated. 
2. Functional Description 

As discussed previously, NPS CORNS§ is a 16-bit correlator that compares a 
data binarv string with that of a reference string and outputs the BCD number of 
matches. As illustrated in Figure 2 on page 9, the correlator can be divided into the 
combinational and sequential logic sections. 

The sequential logic area consists of four 16-bit register banks and various 
control signals. Table 1 on page 10 is a summary of the input and control pins that are 
contained in this section. Each of the four 16-bit register banks are identical and hold 
data, reference. masking and test binary string information. The register bank consists 
of 16 “D” flip flops controlled for either serial or parallel input bv a 2-1 multiplexer and 
the serial parallel control (SPCON) line. In the parallel load mode the data string 1s 
loaded into the register bank that 1s selected by that control line. The active control line 
allows the clock to toggle the input into the register and inhibits the other registers. In 
the serial data mode the register banks can be loaded either one at a time or simultane- 
ously. Ifthe serial control line is selected and the associated control line is activated, the 
data on the input serial line to each register bank is passed. The serial string 1s rippled 
from one bit to the next bit in the register bank at the falling edge of the clock. If de- 
sired, the output control line (OU TCON) can be active every 16 clock cycles to gate the 
output and synchronize the serial data stream. A listing of the correlator output pins is 
included in Table 2 on page 10. 

After the register banks are loaded, the correlation process takes place at each 
clock cycle. The exclusive nor (XNOR) circuitry compares each bit of the data register 
bank and the reference register bank and if a match is obtained a ‘I’ is present. The 
mask register allows the user to select the bits to be compared by blocking the output 


of the XNOR circuitry. If the mask register is loaded with all ‘1's all compared bits from 
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Table 1. NPS CORNS8 INPUT PINS 


Parallel input pins 
Toggles the output 
Serial data for MASK register bank 


Se ON Allows the A NOR circuitry to enter the TES] resists 
















bank 





PADIN Test signal to check operation of the input pad 
Power connection to the chip 
Ground connection to the chip 


Table 2. NPS CORN88 OUTPUT PINS 
Serial output from DATA register bank 













the ANOR circuitry will be passed to the input of the combiner. Table 3 on page 11, 
for both binary values columns, illustrates the results with the masking feature disabled. 

If certain bits are not to be included in the correlation process then those bits 
can be masked by the mask register. With the mask register set to ‘I’ for the bits to be 
compared and ‘0’ for the remaining bits, the circuitry will pass to the combiner the 
nuniber of matches from the compared bits plus the number of ’0’s in the remaining bits. 


Table 4 on page I1 column A illustrates that the masking value of ‘OOJIIIIIIIIIIIIV 


Table 3. CORRELATOR RESULTS (NO MASKING) 
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will compare bits 3-16 for matches, and that number of matches plus the first two bits 





will give the number of ‘1’s passed to the combiner. This method of implementing a 
masking scheme was chosen because, no matter how many bits to be compared, if the 
bits chosen match perfectly then the output will be a BCD °10000’, or the decimal 
equivalent of 16. This allows the designer to check the output pin OUTS to determine 
if a complete correlation is obtained, no matter how many bits were masked. Table 4 


column B demonstrates this feature. 


Table 4. CORRELATOR RESULTS (WITH MASKING) 
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It is important to note that each bit of the correlator is treated the same; that 













is, the position of the bit is irrelevant. Serial output lines from each register bank allow 
for expansion of the correlator. With the addition of an external adder, two correlators 
can be combined and a 32-bit correlation process 1s possible from either serial or parallel 
input data. The test register bank in this section was included to improve testability and 


will be discussed in the next section on testability issues. 
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The combinational logic section contains combiner and adder circuits. The 
combiner is four identical logic circuits that each convert a four input signal from the 
NNOR circuitry to three outputs that represent a BCD number. For example, if the four 
input lines to the combiner where all ‘1's, then the three lines out of the combiner would 
be ‘100° or the decimal representation of four. The outputs of the combiners are then 
processed by the adder circuitry. This network 1s composed of three 4-bit full adders. 
In the first set of two full adders, each adder adds the three outputs from two of the 
combiners and produces a 4-bit result of the number of ‘l’s on the input lines. The 
carrv-in and the most significant bit to each of these two adders are set to ‘0’. The final 
adder adds the results from the previous set of adders. The final result is the five output 
lines which includes the carrv-out pin. If the data stream matches the reference stream 
and the mask register bank 1s set to all ‘l’s, the output from the last adder 1s “10000 or 
the decimal equivalent of 16. When the output control line (OUTCON) Its active the 
Outputs are presented at each clock cycle. 

3. Partitioning for Testability 

The functionality of the design was validated by the MOSSIM II simulation 
program. but the design offered little observability within the circuit. The initial design 
used 35 pins of a 40 pin pad frame package leaving five pins to access the internals of 
the chip for possible fault isolation. Although other VLSI chips have been manufactured 
for NPS by MOSIS, this was the first chip that would be tested upon return. With that 
in mind it was decided that adding complex circuitry to conduct insitu testing or adding 
redundant features was increasing the risk of producing a faulty VLSI chip. However, 
a test register was added to partition the combinational section from the sequential sec- 
tion. When the test control line (TSTCON) is raised, the input to the combiner from the 
XNOR circuitry 1s fed to the test register bank. The output of the register bank is then 
clocked out serially and read from the corresponding serial output. This allows for 
Observability of the critical interface between these two sections. An input pad 
(PADIN) and an output pad (PADOUT) were connected without additional circuitry to 
validate the pad frame characteristics. The remaining pin was taken from the most sig- 
nificant input bit of the adder to check the output of the combiner. This partitioning 
of the design, while not elegant, significantly increased the observability of the manu- 


factured chip. 


B. MAGIC LAYOUT SYSTEM 
MAGIC is an interactive layout editing svstem that was developed at the University 
of California at Berkeley for the design implementation of custom VLSI circuits. At 
NPS it allows the circuit designer, using a mouse and either the Advanced Electronic 
Device (AED) or one of three Integrated Solutions Incorporated (ISI) work stations, to 
layout circuits from the transistor device level to a full custom VLSI circuit. If transistor 
level design is required then knowledge of silicon semiconductor theory is a prerequisite. 
The goal of MAGIC ”... is to increase the power and flexibility of the layout editor, so 
designs can be entered quickly and modified easily.” [Ref: 14 ,p. 20]. Additional goals 
for an efficient routing capability, short turnaround time for small bug fixes and allowing 
the designer the abilitv to rearrange a cell in order to try out a different topology were 
also considered by the designers of MAGIC. Along with these lavout goals a design-rule 
checking procedure to incrementally check a circuit for proper layout during the circuit 
creation was developed. This section will not attempt to provide the details that a de- 
signer must know to produce a design layout in MAGIC. The topographical layout 
procedures are described in detail in the nine tutorials provided in the MAGIC user’s 
manual [Ref. 3]. An overview of silicon semiconductor technology, selected layout fea- 
tures of MAGIC, and an examination of the design-rule checking process will be dis- 
cussed in this section. 
1. Silicon Semiconductor Technology Overview 
“A metal-oxide-silicon (MOS) structure is created by superimposing several 
layers of conducting. insulating and transistor forming materials.” [Ref. 15.p. 3]. 
Figure 3 on page I4 is the palette of materials that can be combined in MAGIC to 
construct a VLSI circuit. The principle transistor building blocks are the ndiff, pdiff. and 
polysilicon materials. The ndiff material is negatively doped silicon that is rich in 
electrons and superimposing this material with polysilicon 1s interpreted bv MAGIC as 
a nMOS transistor. A pMOS transistor is created by overlaying the polysilicon with a 
positively doped silicon or pdiff material. The technology that embraces both nMOS and 
pMOS technologies is called Complementary MOS (CMOS). MAGIC allows imple- 
mentation of both nMOS and scaleable CMOS (SCMOS). SCMOS is CMOS technol- 
ogy that can scale the physical dimensions of the completed design prior to chip 
fabrication. CMOS was selected to produce NPS CORN88 because of its almost zero 
static power dissipation, its rise and fall transition times are of the same order, and 


transmission gates can be cascaded in CMOS but not in nMOS. 


13 


metalt 


metal2 
purple 


ndiff HA Re . 


P 





Figure 3. MIAGIC Materials Palette 


MAGIC lavout is based on the Mead-Conwav stvle of design which simplifies 
design rules and circuit structures. These simplified design rules are possible because onlv 
designs whose edges are Vertical or horizontal are allowed. This design restriction sac- 
rifices some chip density, but it is compensated for by reducing design time. An exam- 
ination of a CMOS inverter. from the functional schematic to the MAGIC graphical 
lavout represented in Figure 4 on page 15, will illustrate the basic fundamentals required 
in building a CMOS circuit. 

The CMOS inverter is composed of an nMOS transistor and a pMOS transistor. 
These transistors are often referred to a N-switch and P-switch, respectively, because 
that is their basic function in a digital circuit application. A ‘0’ closes a P-switch and a 
‘l’ closes the N-switch. In the CMOS inverter the P-switch 1s located on top and con- 
nected directly to Vdd. When a ‘0’ is applied to the gate of the P- switch then the switch 
closes and Vdd 1s switched to the output. The ‘0’ is also applied to the N-switch at the 


same time and the N-switch is turned off. When a ‘1’ is on the input of the N- switch 
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Figure 4. NMIAGIC Layout of a CMOS Inverter 


the switch is closed and ground is passed to the output. The P-switch with a ‘1’ on the 
input is turned off. In the MAGIC design of the inverter the interactive editor interprets 
the ndiff or pdiff over-laid on the polvsilicon as a nMOS or pMOS transistor, respec- 
tively. An alternative to painting ndiff or pdiff material over polysilicon is to use the 
nfet or pfet paint from the palette to create the appropriate transistor. Besides the two 
transistors in the inverter, Figure 4 shows the metall runs of Vdd and ground. The Vdd 
is physically connected to the pdiff material with a contact called pdiffcontact or pdc. 
Conversely the ground connection to the n-diff material is called ndiffcontact or ndc. 
When the MAGIC design is readied for fabrication, and a CIF file is generated. the 


MAGIC program will cut a connection square in the mask to allow for the physical 
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joining of the materials. The other two contacts that are associated with the inverter 
located on the Vdd and ground metall runs are the substrate contacts. They are used to 
maintain proper substrate voltages and to prevent latch-up. The Nncontact or nnc is 
to provide Vdd to the n-well around the p-transistors, and Ppcontact or ppe provides 
ground to the p-well around the nMOS transistors. 

Latch-up is a CMOS circuit parasitic feature that results in the shorting of Vdd 
and ground lines together because of the inclusion of both nMOS and pMOS. In the 
inverter example listed latch-up could occur during the transition of the input waveform. 
There is a remote possibility that both the pMOS and nMOS transistors are conducting 
at the same time channeling the Vdd directly to ground. Although this could occur for 
only a fraction of second it can damage the circuit over an extended period of time. Al- 
though fabrication processes have virtually eliminated latch-up problems the following 
design rules from: Weste [Ref. 15, p. 59] further reduce the possibility of latch-up occur- 
ring. 

e Every well must have a substrate contact of the appropriate type. 


e Every substrate contact should be connected by metal directly to a supply pad 
(1.e., no diffusion or polvsilicon underpasses in the supply rails). 


© Place substrate contacts as close as possible to the source connection of transis- 
tors connected to the supplw rails (1.e., Vss n-devices, Vdd p-devices). A very 
conservative rule would place one substrate contact for everv supply connection. 


e Place a substrate contact per 5-10 logic transistors. 


e Lav out n- and p-transistors with packing of n-devices towards Vss and packing 
of p-devices towards Vdd. Avoid convoluted structures that intertwine n- and 
p-devices in checkerboard styles. 

In the construction of a MAGIC cell the assembly of the materials, contacts. 
and routing must meet physical topographical rules. As an example of a simple size rule 
is that Metall width must be at least 3 units wide. The entire set of topological layout 
rules are checked by the design-rule checking algorithm and will be discussed in a latter 
section. 

Additional Knowledge of silicon semiconductor technology is required, when 
designing a VLSI circuit, to determine the timing and switching characteristics, various 
capacitance parasitics, power requirements and physical size of the actual devices. Based 
on the size of the device, for example, the length and width of the transistor, MAGIC 
includes the resistance and capacitances associated with that component in the extracted 


output. The actual mask in CIF format that is transferred to the foundry does not in- 
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clude these capacitances and internal resistances. These capacitances and resistances are 
not included because they will be realized in the manufacturing process. will be realized 
in the manufacturing process. These lumped capacitances and resistances allow for re- 
alistic simulation of the MAGIC design. 

An example of the level of silicon semiconductor technology that is required can 
be shown by examining the is the previously mentioned inverter. The gain, beta, of a 


transistor is computed by: 





aed ant 


iitere pt is the effective surface mobility of the electrons in the channel, ¢ is the 


permittivity of the gate insulator, 7,, is the thickness of the gate insulator, W is the 


iaeeneor thre channel, and L 1s the length of the channel {Ref. 15,p. 40]. The = is also 
called the processing gain of the material. Because the processing gain of n-diff material 
is twice that of p-diff material, u,=2u,, the gain of a similar size nMOS transistor is 
twice that of a pMOS transistor. Therefore, the width of the pdiff channel must be twice 
that of the ndiff channel to provide for the same theoretical gain. The rise and fall time 
for the inverter is also dependent on gain and will also be matched if the ratio of width 
of the pdiff material is twice the width of the ndiff material, Wp=2Wn. Figure 4 on 
page 15 illustrates that ratio of widths between the pdiff and ndiff materials. The details 
of determining associated capacitances, power consumption, — distributed 
resistance capacitance effects and various other silicon technology concerns are pre- 
sented in Weste [Ref. 15] and should not be a concern for the beginning digital VLSI 
designer. 

Once the basic descriptions for the P-switch and the N-switch are understood. 
these switches can be combined in a variety of different configurations to produce nu- 
merous sequential and combinational logic circuit designs. If the circuit design can be 
realized in a Karnaugh map, then these switches along with a complementary switch or 
pass gate can be combined to realize that circuit within MAGIC. 

2. MAGIC Layout Features 
a. Invoking Commands 
As previously addressed, there are nine MAGIC tutorials in the users man- 
ual {Ref. 3] to acquaint the new user with the capabilities of MAGIC. Commands can 


be invoked in MAGIC in three different wavs: mouse, macro and command lines. The 


lg 


box and cursor are the principle focal points on the graphics display to manipulate items. 
The cursor is used to select an item and is in the form of a cross hair. The box is usually 
defined by the mouse’s left and right buttons setting the left lower and upper right cor- 
ners of the box respectively. After the box is made it can be relocated to anv position 
by moving the cursor to the position desired and pressing the right mouse button. The 
center button on the mouse is used to “paint” the box the color taht the cursor 1s 
touching. To “paint” is to lay materials, as defined in the palette illustrated in Figure 3 
on page I4, into an area bounded by the box. 

A macro is another way to control the graphics display and uses previously 
defined single keystroke commands. An example of a macro is typing the letter “a’, 
Which will select an item that is enclosed in the box. Macros can also be user defined 
to perform repetitive commands. | 

The third method of invoking MAGIC commands 1s through the command 
line. The command line is entered by starting the command with ”;” or ”:” and then 
proceeding with the command. An example of this tvpe of command is “:quit” which 
exits the MAGIC editor. 

b. Basic Magic Tools 

There are three basic tools that can be utilized in the MAGIC layout editor; 
box, Wiring and netlist. The desired tool can be selected by pressing the space bar at the 
">" prompt on the editor screen. Because of its utility, the tool that the MAGIC editor 
defaults to 1s the box tool. 

The box tool is by far the most useful tool within MAGIC to lavout leaf 
cells. Using the box and cursor positions as defined by the mouse, leaf cells can be 
“painted” from the transistor level to the most complicated of circuits. The inverter in 
Figure 4 on page 15 was “painted” while in the box tool utility. This “paint” feature and 
the ability to label various nodes enable the designer to construct a leaf cell. Within the 
box tool utility a leaf cell can be copied, reoriented. moved, labeled, and modified based 
on which commands are invoked. The power of this utility is evidenced by the fact that 
all NPS CORNSS leaf cells were laid out in this box utility. This utility is also useful in 
the hierarchical assembly of larger circuit designs by using the “:getcell” command. This 
allows several cells to viewed and manipulated on the graphics terminal in order to 
produce a much larger cell. 

The wiring tool provides an alternative method for manipulation “paint” 
and is used for wiring, plowing and defining arrays. The wiring capability is just what 


its name implies. It provides a way to select the wire to be connected with the left mouse 


button and that wire will be extended to the cursor position when the right mouse but- 
ton is pressed. The wiring tool also allows cells to copied in the “x” and “y” directions 
into an array of identical cells. This provides. an easier way to duplicate leaf cells than 
was available in the box tool. The plow feature is interesting because it 1s used to stretch 
or compact cells. If it 1s used to compact cells it will vield the smallest possible 
topographical area for the cell within the design-rule limitations. 

The third and final tool utility is the netlist tool. This tool makes use of 
MAGIC’s automatic routing feature to make connections between previously defined 
leaf cells. A limitation of this router is that it only works between cells and not between 
pieces of a layout and a cell. Power and ground lines have to run to the initial cells by 
hand because the automatic router can not handle these cases. This automatic routing 
feature is useful when making a large number of interconnections between cells. If this 
feature 1s to be taken advantage of. all connections must abut the edge of the cells. A 
netlist is a menu driven file that describes the set of connections to make between cells. 
Once the netlist file has been completed the cells are automatically routed by invoking 
the command “:route”. This tool is useful because it will route to avoid obstacles in the 
routing path and take the most direct path possible. 

3. MAGIC External Interfaces 
a. Circuit Extraction 

The MAGIC extractor can be used on a single cell or a hierarchical design 
of many leaf cells. It converts the design lavout into transistor sizes and shapes. It also 
recognizes nodal resistances and capacitance within the lavout and includes those values 
in the .ext file. The extractor is relatively fast because if it 1s extracting a high level hi- 
erarchical design it needs only to extract those cells that have been modified and not the 
entire hierarchical design. 

Once this design is extracted by issuing the command “.ext”, the ext2sim 
program is used to convert this file into a .sim file. This .sim file is then used as the data 
file for the sim2ntk program and that .ntk file is then used as an input for MOSSIM II. 

b. Caltech Intermediate Form (CLIF)] Calma Stream Format 

CIF and Calma are standard layout description languages used to transfer 
mask-level layouts between organizations and design tools. CIF 1s the best known lavy- 
out language in the academic community and Calma holds that distinction for the in- 
dustrial community. Magic can produce either form of these output files. 


, 


CIF is invoked by issuing the ”.cif’ command when selecting the cell. At 


NPS, the CIF file 1s primarily used as an interface between MAGIC and the Hewlett 


Me 


Packard 7586B plotter for output of hard copy of the MAGIC lavout. CIF is also used 
to transport the MAGIC file to MOSIS for fabrication. 
4. Design-Rule Checking 

One of the most important features of MAGIC 1s the ability to incrementally 
check for design-rule violations during the layout phase of the design. Each of the tech- 
nologies available in MAGIC has their own design-rules that reside in the technology 
file, and are primarily used when setting up the MAGIC file for fabrication. During the 
design layout MAGIC checks for design rule violations and, if any occur, it will display 
little white dots in the vicinity of the error. Because the editor checks for the design-rule 
violations incrementally when the lavout 1s complete there is no reason to recheck the 
entire design. The design-rule checking feature 1s applicable to single cell layouts as well 
as larger hierarchical design lavouts. 

a. Single Cell Layouts 

When laying out a leaf cell in MAGIC there are three basic sets of rules that 
the design-rule checker uses; width, spacing. and overlap [Ref. 3,pp. 255-262]. Know- 
ledge of these rules is paramount in order to efficiently layout materials. These layout 
materials are listed as tile types and their abbreviations are hsted in Table 5 on page 
21. The design-rules for C\I[OS technology are summarized in Table 6 on page 21 and 
Table 7 on page 21. The width rule requires that any material or tile types contained 
in Table 5 on page 21 must meet or exceed the width specified in Table 6 On pageue: 
in both the “x” and “vy” directions. The unit of measurement is a lambda unit and that 
can be converted to microns if the fabrication technology is known. NPS CORNSS used 
3 micron technology for everv 1.5 lambda units. For example, if a minimum width of 2 
lambda units was used, that fabricated width would be 4 microns. 

The spacing rules in Table 7 on page 21 are a little more complicated. The 
actual spacing between materials 1s computed by the Manhattan distance. If the points 
are aligned either vertically or horizontally, then the spacing is between adjacent points. 
For objects not horizontally or vertically aligned, the distance is the length of the longest 
side of the right triangle forming the diagonal between the points. Figure 5 on page 22 
illustrates the Manhattan distance and how it is measured. The final column in Table 7 
On page 21 indicates whether touching is “ok” or “illegal”. If “touching ok” is indicated 
then the miaterials must be either immediately adjacent or separated by the distance 
stated. If “touching illegal” is indicated then that eliminates the provisions of materials 
to be immediately adjacent. “Touching illegal” also checks the different layers or planes 


and will report those violations. 
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Figure 5. Manhattan Distance 


Table 8. ABBREVIATIONS FOR SETS OF TILE TYPES 
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Table 6. DESIGN-RULE WIDTH REQUIREMENTS (IN LAMBDA UNITS) 
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The overlap rule requires that certain kinds of overlays between materials 
be prohibited. Transistors can not overlap transistors of the same tvpe. If dmc and pmc 
materials are touching they must completely overlap each other. These overlap rules are 
required for proper generation of the CIF generation and circuit extraction. 

b. Hierarchical Layout Rules 

There are three overall rules that govern the design-rule checker when it 
apphes to a hierarchical layout, and each of these three rules must be satisfied inde- 
pendently. A hierarchical layout is built from smaller cells and NPS CORNSS8 is an 
example of a hierarchical lavout. Figure 6 on page 23 shows the cells involved in the 
higher level design of NPS CORN88. These leaf cells were combined by a CFL program 
and this combination process will be addressed in a later section. Figure 6 on page 23 
shows that “regcell” 1s the “parent” for the five “children” below. “Regcell”is duplicated 
mn the “x” direction and stored in the parent cell “regbank”. The “children”, “regbank” 
and “comadd” are then combined into the parent “chip”. This “parent” “child” relation- 
ship must be understood to examine how design-rule techniques are applied to hierar- 
chical layouts. 

The first design-rule when considering hierarchical layouts is that the 
“paint” in each cell must obey all design-rules by it self. The second rule involves the 
interface between cells. This interface could create a design-rule error because abutting 
connections could violate the design-rules. These errors will show up in the parent cell 
at the interface between the two cells. The third error is that each array must be error 
free by itself. If the adjoining cells interact to produce a design-rule error the violation 


will be presented in the parent cell. 
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Figure 6. NPS CORNS8S8 Hierarchical Structure 





With MAGIC design-rule features the chip designer can concentrate on the 
chip design vice the mvriad of design-rule details. If a design-rule error is discovered a 
simple command “:dre why” will explain the difficulty. 
5. MAGIC Lavout of NPS CORNS88 
NPS CORNSS was designed as a hierarchical lavout of several small cells as 11- 
lustrated in Figure 6. The cells are a combination of leaf cells from MAGIC’s library 
of cells. For example. “CR_dat” leaf cell is a “D” flip flop and a multiplexer from the 
library. These two cells were assembled, modified and routed so that thev would prop- 
erly interface with the cells adjoining, both horizontally and vertically. This procedure 
was followed for the remaining subcells in the final chip assembly. The use of library 
cells not only saved design time but also ensured that those cells would function properly 
because they had already been exhaustively tested before inclusion into the library. 
As each leaf cell was completed that cell was functionally verified by using the 


MOSSIM I] and SPICE simulators. Once all the cells were laid out and functionally 


tested they were assembled into the completed chip with a CFL program. This allowed 
for quick turnaround between the modification of a subcell and the assembly of a com- 
pleted hierarchical chip lavout. The ability to construct a leaf cell and test it during the 
incremental design process resulted in a final chip assembly that had only a few routing 


and alignment errors between cells. 


C. SIMULATION 
1. Preparation for Simulation 

Once the MAGIC file has been checked for mask lavout errors Usingeie 
design-rule feature in MAGIC, the file can be extracted for each cell in the hierarchical 
design. The files that are produced in MAGIC and the paths to different simulation 
routines are illustrated in Figure 7 on page 25. This extracted file contains the nodes. 
of the circuit and also includes total capacitance to ground, and a lumped resistance 
calculation for each node. It further defines the layout of transistors by tvpe and size. 
The sim2ntk program sets up the file to be simulated, identifies the input pins and sets 
the strength assigned to the transistors, either CMOS or nMOS. The commands re- 
quired to convert the NPS CORNSS8 layout design contained in the “CR_chip.mag” file, 
to the “CR_chip.ntk” file that is used in the MOSSIM II simulator, are included in 
Figure 8 on page 26. 

2. Background 

MIOSSIM_ If is a logic simulator based on switch-level logic that models the 
MOS digital circuit as a network of nodes connected by transistor switches. Because of 
this logic level modeling. N1OSSIM II can handle large VLSI designs with long input 
sequence vectors. The MOSSIM II program js written in Mainsail programing language 
and using the network description language (NDL) the user can fully describe a network 
to the simulator. Ifa design can be fully described in this manner, it does not have to 
be laid out in MAGIC to be simulated. This feature was not used in the development 
of NPS CORNSS8 and will not be discussed. 

The MOSSIM II user’s manual [Ref: 8] provides all the details required to use 
MOSSIM II. The actual commands that are involved in controlling the MOSSIM II 
program will be detailed in Chapter 4 along with the development of the MOS2DAS 
translator. An overview of MOSSIM II functional capabilities will be discussed in this 


section along with the applications that applied to the testing of NPS CORNSS. 
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Figure 7. NMLAGIC to Simulation File Conversion Process 


3. Overview of Capabilities 

MOSSIM I] capabilities can be examined by separating the source program into 
Meordiilerent sections, initialization and drive. Figure 9 on page 27 is the MOSSIM II 
program that was used to simulate NPS CORNS88 and will be used to illustrate the basic 
structure of a NIOSSIM II program. In the initialize area the file to be simulated 1s read, 
and the clocking scheme. vector and watch assignments are defined. In Figure 9 on page 
27 the file read is “CR_chip.ntk” and the clock 1s three phases, ‘010°, with a node name 
of “clk”. The vectors defined are “ins” for the 16 parallel input nodes, “control” for the 
control lines, “select” to select a serial data input, “misc” to set up the serial parallel and 
Output control lines. and finally “outs” to define the five output pins. The watch com- 
mand identifies vectors and nodes of interest that need to be observed. The vectors 
“outs” and “ins” and the node “clk” are “watched” in this program. Once the iniualize 
Section is complete. the simulator is ready to start handling binarv assignments to the 
Inputs. 

The drive section of a MOSSIM II simulation program sets or forces the binarv 
Values to the desired inputs and also sets the number of cycles for the simulator to run. 
A cycle is the completion of the one clock cvcle. The output values for the watch de- 


fined nodes are observed after each cycle or phase as specified. In this case the watch 
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Figure 8. MAGIC ”.mag” File to ’.ntk” file Commands 
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command “/*” indicates that the outputs will be observed after every clock phase, or 
three phases per cycle. The program in Figure 9 on page 27 forces the parallel inputs to 
the desired values and the values are then loaded into the respective register at the 
trailing edge of the clock pulse. To prevent erroneous data at the output during this 
register set up process, the output lines are disabled. Once all the registers are loaded, 
the outputs are enabled and the vector “outs” contains the BCD representation of the 
number of matches. The remaining program ripples an error bit into each bit of the data 
register to verify proper operation of the correlator. The output line reports the cycle 
number and the nodes of interest. An “X” state is an undefined state and will occur at 
a watched node if that part of the network has not been initialized or the node voltage 
lies between the logic thresholds. 

Additional features of the MOSSIM II simulator can be obtained by setting 
“switches” to turn on or off. Four of these switch positions are helpful in run time 


testing of the circuits. These run time switches are summarized below [Ref. 8.p. 18]: 


e Ternary--provides a rigorous test to discover possible timing errors. If a design 
simulates successfully in the ternary mode the circuit will function correctly for 
those input sequences regardless of the actual switching and communications de- 
lays of the circuit. This switch must have a two phase, non-overlapping clocking 
scheme as the design clock, and will fail for clock generators and edge triggered flip 
flops. This switch can also determine race conditions within a circuit. 


e Restore--checks for and reports unrestored CMOS logic levels. 


e¢ Explain--the simulator makes an attempt to diagnose the reason for the “x” state. 
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»comment load bit select data 

DProree 1ns:JTIIITIVIIII1111 

»force control:0010 

yevele™ 1 
Peneeoues OOOO) Ins: TTTITILITIII1I111 clk: 
Zeeeoues COU00 ins: LIVITIVVIIILIT11 Clk; 
Pee Gules: OO000 inS-1IITIVIT1IT11111)] clk; 


9 8) 


»comment load signal data 

Meerce ins: 1111121111111111 

>»force control:1000 

>»force misc:1l 

»cycle 1 
Beeiiereucs: XXXXx ins: LLILILIITI11I111111 clk: 
Bee e@uics = xxx ke Ins lI elk: 
Pe simeurs:OLO00 ins: 1 TIIILIVILII1111 clk: 


(Se eS) 


> 

>»comment changes mask register 

Pforce control:0010 

yiroree. 1ns:0000000011111111 

»cycle 1 
Peemeucs: 01000 1ns:0000000011111111 clk: 
4.2] outs:01000 ins:0000000011111111 clk: 
fee | Outs 01000 1ns:-0000000011111111 elk: 


oO — © 


Figure 9. NPS CORN88 MOSSIM IJ Source Program 


e Statistics--will print run time Statistics including number of steps, CPU time re- 
quired to run and other timing details. 
4. NPS CORNSS Test Vectors 
The selection of test vectors to properly stimulate the circuit design is an im- 
portant aspect in the simulation procedure. As mentioned previously a C program was 
Written to simulate 65,536 (2%) possible test vectors. An additional program Verified that 
the correct values for each test vector was obtained. These programs took more than 
23 hours to simulate on the VAX 11/785. While this exhaustive method provided the 
maximum test coverage, a subset of these vectors was found to provide acceptable cov- 
erage with far fewer test vectors. 
This subset of vectors was heuristically determined and included only 63 vectors. 
The first 16 vectors rippled an error through the data bits and verified a BCD output of 
15 was observed at the output. The second set of 15 vectors insured that the output 
would produce BCD values from 0-16. Onlv 15 vectors are needed because the BCD 
value for 15 was determined in the first case. The next two vector sets involved changing 
the reference register and the mask register. Setting the data register with all ones an 
error Was rippled through the reference register bits and the output observed. The mask 
register Was similarly tested with 16 additional vectors. These 63 test vectors func- 
tionally validated NPS CORNS8S and provided a reasonable set of test vectors for 
MOSSIM LI. and the follow on testing of the fabricated chip. 


D. CFL 

“Coordinate Free Lap (CFL) is a library of subroutines written in C intended to fa- 
cilitate the construction of VLSI circuit lavouts.” [Ref. 16]. Once the required leaf cells 
have been laid out in Magic, then the CFL algorithms provide powerful tools to dupli- 
cate, align and combine these cells into the assembled chip. The CFL routines were used 
twice in the development of NPS CORN88, once to assemble the body of the chip, 
Figure 10 on page 29, and in the final assembly process to attach the pad frame and 
associated routing. The description of CFL procedures, format and symbology are de- 
lineated in the CFL reference manual, [Ref. 16], but discussion of the salient features of 
Figure 10 on page 29 will illustrate the strengths of this program. 

1. Hierarchical Assembly of Magic Leaf Cells 

As previously mentioned Magic is used to generate the leaf cells that are as- 

sembled with CFL to produce a composite chip. The leaf cells used by Figure 10 on 


page 29 include the four register cells and an XNOR cell. Each of the register cells 


minclude <stdio.h> 
#include <time.h> 
momclLude "cfl.h" 


main( ) 
SYMBOL «chip; 
Gmisete( format’, "maqic” ); 
Grlstart( Scmos” ); 


errsecv( "grain", 1) ; 


eh isp mites “CR Comp J, gst CR dat” )); 
clube ies ( CRamer) chi py 


el gulje) mbes Chemask  \eechipy, 
ei paeelligs( "CR test"},chup); 
BoqeCR tegcell' chip); 
Gnip = nux(gs("CR regcell"),16); 
Poi ke reg oalivn, Cll) 


chaie 
ehip 
Giri 
chip 


ll(gs("CR_comadd"),gs("CR_regbank")); 
BEcvCgs@ GR left" )\,chip, 27) 
biel gs CR UEOD) ))) ; 

Peers ie, gS ( 'CRETIght” jy.e-7 ); 


PSG Chee @,.1Chip ); 
GmEesteop(), 





Figure 10. CFL Composite Chip Assembly 


(eke dat, CR ref. CR mask’. “CR test’) includes a “D” flip flop. 2-1 multiplexer, 
and control lines. “CR comp” contains the NNOR circuitry. After the initial setup 
commands to link the program to the CFL librarv the first construction command lies 
on line Yi. Line numbers have been added to the program in the comments column to 
refer to them in this discussion and are not normally part of the program. Line O1 uses 
the “gs” command to get the library symbols “CR comp” and “CR dat” and the “Il” 
(lower case LL) command aligns them left border to left border with the “CR_dat” cell 
on the top. This new cell is stored as “chip”. Figure 11 on page 3] illustrates the CFL 
construction of the “CR _regcell” after lines 01-05 are completed and the “ps” command 


is used to put “CR_regcell” into “chip”. Line 06 duplicates the “CR_regcell” 16 times in 


the “x”direction and line 07 stores that symbol as “CR_regbank”. The remaining lines 
align the remainder of the leaf cells to the basic chip. The combiner and adder leaf ceil, 
“CR_comadd”, was built as a large cell because the interconnection between the com- 
ponents were difficult to realize in CFL. It was easier to build the cells in Magic and then 
duplicate and connect them while observing the results on the Magic screen. The de- 
signer must determine if the cell can be replicated more easily in Magic or by using the 
Cris tprosiatm 
2. CFL Advantages/Disadvantages 

The obvious advantage for using CFL is that the individual leaf cell can be 
modified in Magic and the CFL program can assemble the chip with that modified cell. 
Ifa cell was modified in the Magic drawing (for example, one of the register cells), each 
cell of the Magic drawing would have to be modifted, or 16 modifications. This could 
create errors in the design and also 1s much more time consuming than using CFL. Use 
of CFL reduces the development time considerably and new modifications of the cell can 
occur expediently. The disadvantage of using CFL is that the cells must be constructed 
block-lrke for ease in alignment during assembling routines. Each interface that is as- 
sociated with that leaf cell must be designed with the adjoining leaf cells in mind. 
“CR_regcell” in Figure 12 on page 32 is a good example of well constructed leaf cells for 
use in the CFL program. The cell is “finished” to each border. Nottee how the outa 
of each cell must line up with the adjorning cells nputs. The other disadvantage of using 
CFL is that of labeling external connections for the chip. If a leaf cell is burlt with la- 
bels, those labels will be duplicated, when the leaf cell 1s duplicated and any attempt to 
run a simulation program using those labels as inputs or outputs would not succeed 
because of label duplication. A frame must be built that contains connections to the 
composite clip that mncludes labels. In Figure 10 on page 29, CR leit, CR Tick 
and “CR_top” provide those connections and associated labels. 

In summary, CFL is a powerful assembly tool for leaf cells but not without a 
price. The extra effort expended in designing the leaf cell to align properly with adjoining 
cells, and providing leaf cells that contain labels and associated connections, could be 
considerable and not worth the effort. NPS CORNS88 was a combination of both as- 
sembly technologies. The combiner adder circuitry was constructed in Magic as a large 
leaf cell because the individual modules were easier to connect on the Magic screen. The 
individual register and XNNOR leaf cells were designed in Magic but assembled into a 


16-bit register bank using CFL. 
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CR_top 
CR__comp 


CR_regbank 
| 


CR 


LYON YD 


CR comadd 


CR_reacell 





Figure 11. NPS CORNSS8 CFL Block Structure 


E. NMOSIS 
1. Background 

MOSIS. which is an acronym for MOS Implementation System, provides fab- 
rications services for the production of bonded and packaged integrated circuits. Ori- 
ginally it provided services to government and educational users but recently it has 
expanded to the industrial sector. \fOSIS, as described in the MOSIS user’s manual 
{Ref. 11]. is able to combine several lavout designs from different users of the same re- 
quested technology onto a multi-project single silicon wafer and thus dramatically re- 
duce the fabrication cost. Tomovich states, “Instead of paying for the cost of 
maskmaking, fabrication. and packaging for a complete run (currently up to between 
$50 and $60.000), a designer can receive packaged parts for as little as a few hundred 
movies. (nel. 17). Before \iOSIS can fabricate the chip, several steps are required to 


prepare the final design for fabrication. 
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2. Preparations Prior to Fabrication 

Once the circuit design has been validated, the designer must choose a pad 
frame to encase the design. There are several standard pad frames recommended by 
MOSIS and available from their library of cells. The frames come in 28, 40. 64, 84. 108, 
132 pin packages and they facilitate the entire packaging and bonding process. It is re- 
commended that one of these standard frames be used along with the SPADS program 
to generate the necessary pads and associated frame. Carleton describes the procedures 
in producing the pads for NPS CORN88 [Ref. 18]. In all but one instance (the frame 
with 84 pins), all standard frames have a substrate connection at pin #1. It is important 
to rotate the design to enable this pin to be used as Vdd. The associated routing from 
the basic design to the pads is done by a CFL program, whose methodology was de- 
scribed earlier. When the entire chip is assembled ina MAGIC file and has been prop- 
erly validated, the file then 1s converted to the Caltech Intermediate Form, CIF, format. 
This is done by loading the entire design on the graphics terminal and typing the com- 
mand “:cif’ at the prompt. This CIF file is also the form that is needed to print the file 
omeuae NPS Hewlett Packard 7586B plotter. 

Now that the CIF file is ready. an account has to be established with MOSI1S 
to pay for the manufacturing of the chip. “Universities that are teaching classes in VLSI 
design may apply for government-sponsored use of MOSIS using the MOSIS applica- 
tion form for Education.” [Ref. L1.p. 12]. NPS CORNSS8 was funded through this method 
With an account set up by National Science Foundation (NSF). 

3. MOSTS Quality Control 

Once an account has been established. the designer can send the CIF file to 
mies Via the Internet, formerly known as the ARPANET. After W{OSIS receives the 
CIF file it will check that file for syntax errors and thereby validate the syntax. A pro- 
Pram, CIF-CHECKSUM, can be run on the user system and sent to MOSIS to verify 
that the file as transmitted was complete. MOSIS does not validate the design: it only 
ensures that the CIF file is in the proper syntax and no errors were made in the trans- 
mussion of that file. 

MOSIS also monitors the quality of the fabrication foundry, the mask vendors 
and the packaging facility. The mask vendors receive the multi-project tape for E-beam 
tooling and the resulting mask must meet tight defect specifications. MOSIS installs 
several designs on each of the multi-project wafers to act as process monitors. The vield 
and parametric specifications for the process monitors are checked by both the vendor 


and MOSIS before the wafer is accepted. Once the wafer is accepted it is sent to the 


28, 


packager for assembly into the dual in-line package, DIP. “Packagers are qualified on 
the basis of bond pull tests and must follow strict static electricity control procedures in 
handling user’s projects.” [Ref. ]l.p. 2]. When the packaging specifications are met a Set 
of bonded and packaged integrated circuits are returned to the user. Mosis produced 
twelve NPS CORNS8$8 custom VLSI chips 1n six weeks at the modest cost of $1400.00. 
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Il. NPS VLSI DIGITAL TEST FACILITIES 


A. BACKGROUND 

As digital technology has matured and become more complex, the capability to test 
these circuits have become more sophisticated. The advent of CAD tools to design cir- 
cuit lavouts has lead to more full custom VLSI design implementations. Each of these 
custom VLSI designs requires a unique test program to functionally validate both the 
design level and fabricated chip. Hnatek states that, “Testing is rapidlv becoming the 
largest portion of recurring costs in the VLSI device manufacturing process.” [Ref. 19,p. 
22). The NPS CORNSS design was previously validated bv the MOSSIM II simulator, 
fabricated by MOSIS., and will be used as an example throughout this chapter. 

This chapter will examine the digital test facilities at NPS and 1s separated into three 
sections. The first of these sections will examine the Digital Analysis System (DAS) 
model 9100 and its capabilities and limitations. The second section will detail the Device 
Verification Software (DVS) model 50 functions and its interface with the DAS 9100. 
The final section will discuss the set-up and testing of NPS CORNSS. 


B. DIGITAL ANALYSIS SYSTEM (DAS) 9100 
]l. Overview 

The DAS 9100 is a stand-alone, modular assembly of various configurations 
that can perform selected pattern generation and data acquisition functions. This mod- 
ularity 1s engineered into the DAS 9100 mainframe by allowing the user the ability to 
install different data acquisition and pattern generation modules. The DAS 9100 Series 
Operator manual [Ref. 12] details the numerous different module options available as 
well as providing an in-depth description of the DAS 9100 functions and capabilities. 
Table 8 on page 36 reflect the modules available for the DAS 9100 and summarizes their 
capabilities. Up to six of these modules can be installed in the DAS 9100 mainframe. 

The DAS 9100 can be used as a logic analvzer, as a pattern generator or as a 
combination of both. One of the advantages of the DAS 9100 is that its operations are 
controlled by interactive menus. The data acquisition and pattern generation modes of 
Operation, and their respective menus, will be discussed in this section and is only an 
overview of the information contained the DAS 9100 series operator manual [Ref. 12]. 


The external interfaces from the DAS 9100 will also be addressed in this section. The 


Table 8. DIGITAL ANALYSIS SYSTEM (DAS) CAPABILITIES 


MODULE te yae # CHNS SE lee ey MAX’ 
INod 


[oia0s*Y Data Acquisition [8 | loomHiz [a0 


GPIB Interface to ll 
DVS50 

KR5252 Connects 2 DAS 
units 

Hardcopy Inter- Printer 

face 


Data Storaee 









actual connections to the device under test (DUT) and the test results will be included 
in a latter section. 
2. Data Acquisition 
a. Nlodules 

The maximum number of parallel data acquisition channels that can be 
processed by the DAS 9100 is 104 at one time. This configuration is obtained by in- 
stalling three 91A32 modules and one 91A08 module. Some discussion of each of these 
modules 1s necessary to examine the capabilities of the DAS 9100. 

The 91A32 can acquire 52 channels at an internal or external clock interval 
ranging from 40ns to 5ms or a maximum clock rate of 25Mz. Each 91A32 module in- 
stalled can be run at a different clock rate and contains two clock qualifiers. These 
Clock qualifiers are used by the DAS 9100 to provide a condition on storing the data 
acquired into memory. If both clock qualifier lines are used, and if those lines meet 
preset conditions, then the data acquired is stored in memory. Each 91A32 module 
controls four data acquisition pods that each contain eight probes to hook to the DUT. 

The DAS 9100 can support up to four 91A08 modules and each can acquire 
and store eight channels. This module, with a special clock probe, can acquire data at 
a rate of 1OOMHz. This module can also use a internal or external clocking scheme and 


each module has a clock qualifier line. The 91A08 module can also acquire and store 
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glitches on all acquisition channels. A glitch is defined as two or more transitions oc- 
curring within anv given clock cvcle. 

The two data acquisition modules, 91A32 and 91A08, are compatible and 
can be used at the same time within the mainframe. The first of these combinations is 
the AND mode and operates both modules simultaneously at the clock rate set for the 
91A32. The ARMS mode allows different clock rates for the modules, with the 91432 
enabling the 91A08 trigger to produce a display similar to an oscilloscope sweep. 

b. AMlenus 

During the logic analysis function of the DAS 9100, the data acquisition 
modules acquire and store digital patterns generated by the DUT. Five interactive 
menus on the DAS 9100 are used to set up the clocking scheme, specify channel as- 
signments, determine trigger specifications and display the data. Each menu is detailed 
in its own section of the operator’s manual [Ref. 12] but an overview is provided to 1l- 
lustrate the logic analvsis function of the DAS 9100. 

The Channel Specification menu controls the display format for the incom- 
ing data to be used by the Trigger Specification, State Table, and Define Mnemonics 
menus. [he Channel Specification menus also specifies the input voltage thresholds to 
be used bv the probes and the which defaults to TTL voltage levels. Each data acqui- 
sition probe has a threshold switch physically located on the back of the probe that can 
switch to “NORM” or “AUX”. The “NORM” position lets the Channel Specification 
menu choose between the TTL voltage threshold levels or a “VAR” threshold that can 
Pemeemoctween -2.5V to +5.0V. If the “AUX” switch is chosen on the probe then the 
threshold voltage can be set to MOS voltage ranges, which can be between -10.0V to 
+20.0V. [he “NORM* or the “AUX” position switch settings can not be mixed in each 
pod. 

The Trigger Specification menu is used to set up data acquisition and stor- 
age conditions. The menu defines the data acquisition modules to be used, determines 
the clock rate, sets up clock qualifiers and word recognition patterns. Each of the 
modules has its own sub-menu to control the trigger specification. The clock qualifiers 
set parameters on when to store data acquisition. The word recognition feature allows 
the DAS 9100 to set a trigger for each occurrence of the word in the data acquisition 
process. This makes it relatively easv to find a high interest pattern or to use that trigger 
to start another set of pattern sequences. Usuallv, both the clock qualifier and word 
recognition features are set to the “don't care”, “X”, svmbol to allow storage of all data 


acquired and not set the trigger on the word recognition feature. 
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The sub-menu for the 91A08 does everything that the 91A52 does and it can 
set the trigger on glitches. The 91A08 always acquires and stores the glitches, but if the 
trigger is set “on” for glitches it is easier to find where the glitches occurred. This menu 
also sets up Whether the ARMS or AND clocking scheme is to be emploved. 

The State Table menu provides access to the data acquired and reference 
mieniories. This menu can show either the data acquired from the sub-menu acquisition, 
the reference memory from the sub-menu reference, or a comparison of both reference 
and acquired data. This menu is useful when comparing two files but the information 
is in hex format and not waveform display so it can be tedious to compare. 

The Timing Diagram menu displays the most recently acquired data in a 
standard digital waveform format for both the 91A32 and the 91A08 modules. Up to 
16 channels can be displaved and this menu can magnify the display. step through the 
entire memory of acquired data a “window” at a time. place a cursor at a run time of the 
pattern and read out the digital values of all channels acquired. The waveforms corre- 
spond to the pod that acquired the data and names can be added to the waveform dis- 
plav to make it more intelligible. 

The final menu associated with data acquisition 1s MImemonics. This menu 
can generate the set up for the state table display. Several different tables can be defined, 
and then the data acquired can be presented in format of that table. This is particularly 
useful if the user wants to observe several different formats of the acquired data. 

The data acquisition features of the DAS 9100 are impressive but it can be 
tedious to enter the specifications via the DAS 9100 kevboard. The menus make it 
somewhat user friendly, but a study of the user’s manual is required to use data acqul- 
sition on even the simplest circuit. The DAS 9100 at NPS lacks a tape recorder to save 
all the set-up data and reference waveforms. These must be initialized every time the 
DAS 9100 is powered up. This is not only tedious and inconvenient, but it 1s an excel- 
lent opportunity to make input errors. Nevertheless, the data acquisition function of the 
DAS 9100 does provide the user with a valuable tool to analyze the fabricated chip. 

3. DAS 9100 Pattern Generation. 

The DAS 9100 generates clock and data signals to the DUT in the pattern 
generation mode. Two pattern generator modules are available, 91S16 and 91832. The 
clocking rate for either module is limited to 25 MHz and can either be internally or ex- 
ternally generated. If all six modules are configured to 91832 pattern generation mod- 
ules the DAS 9100 can provide 192 channels of patterns. This would leave no slots 


available for data acquisition, so the practical limit for pattern generator modules, if only 
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one DAS 9100 is used, 1s less. Patterns can be generated in either of two wavs. The 
91S16 1s an algorithmic pattern generator that uses a nine program instruction set to 
provide branching. looping. and other algorithmic patterns for 16 channels. Only one 
91S16 can be installed in the DAS 9100, but it can be used as a controller for the in- 
stalled 91832 modules. 

Each 91832 module generates 32 channels of RAM-based patterns. This feature 
requires the user to input each channel sequence into RAM memory. If the 91816 and 
meee mnodules are installed together, the 91$16 controls the master cycle clock. There 
are two Operating modes when the two pattern generator modules are to be operated 
simultaneously, sequential and follow 91S16. 

In the sequential mode each module operates separately but the 91S16 supplies 
the clock signal. When the 91S16 algorithm reaches the end of its program it will recycle 
mameime pattern sequence generated by the 91S32 is completed. In the follow 91S16 
mode the 91816 has active control of the pattern generated by the 91S32 and can algo- 
rithnucally control] the pattern sequence. 

The difficulty in using the DAS 9100 for pattern generation 1s the same difficulty 
that was mentioned for the data acquisition feature, the tedious manner that the input 
must be specified. While 16 channels can be generated by an algorithm controlled by 
the 9I1S16 module, the 91$352 pattern sequences require each channel to be individually 
defined by use of the kevboard. This could be a very long process if a long pattern se- 
quence was required for manv channels. An interface with a tape recorder, or another 
meimorv storage device, that could save and load these long patterns once the power was 
shut down would be invaluable. 

An important feature of the DAS 9100 1s the ability to run a pattern sequence 
test pattern and compare until the next sequence either compares or do not compare. 
As an example, the initial results of the NPS CORNSS test sequence were stored in the 
compare file. The test was rerun and compared with the original test until an error was 
found. This enabled many test runs to be compared to each other to run a much longer 
test. 

4. External Interfaces 

There are four external interfaces defined in the DAS 9100: General Purpose 
Interface Board (GPIB), RS-232, Tape drive, and Printer. The GPIB interface allows 
parallel data transmission between a host computer and the DAS 9100, which acts as the 


talker and listener. The NPS test configuration is set-up so that a personal computer 
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(PC) running the DVS50 software program can provide the inputs to the DAS 9100 and 
display the data acquired from the DAS 9100 via the GPIB interface. 

“The RS-232 interface allows two DAS 9100 systems to be linked together for 
a master slave transmission.” [Ref. 12,pp. 1-3]. This allows the master DAS 9100 to 
control the acquisition of data and pattern generation of another DAS 9100 unit. A 
printer interface 1s provided to produce hard copy results for latter analysis. The final 
external interface capability is through a tape drive unit. This allows storage of all the 
information in the DAS memory, including the set-up of all the menus. This tape drive 
feature would be essential if the DAS 9100 mainframe was operated independently. This 
is because of the time it could save in the set-up of menus and in the generation of long 
sequences of patterns. The configuration at NPS does not have a tape recorder, but the 
DVS50 personal computer supported software performs the function of the tape re- 
corder, so the tape recorder is not necessary. 

An additional interface option available for the DAS 9100 is a power supply to 
apply voltage to the module pods and the DUT. This power supply is not installed at 


NPS and a Power Designs Model 3650-S serves as the system power supply. 


C. 9100 DEVICE VERIFICATION SOFTWARE 
1. Background 

The most difficult aspect in using the DAS 9100 mainframe as a stand-alone 
svstem is the setting up the menus, data acquisition channels and pattern generation 
sequences via the DAS 9100 keyboard. The 9100 Device Verification Software (91DVS) 
allows the user to specifv the data acquisition channels and generate long sequences of 
patterns through a high level language program. The 91DVS provides a user-friendly 
menu driven program to functionally test the DUT and 1s defined in the 91DVS user's 
manual [Ref. 20]. The 91DVS requirements include DOS 3.0 or higher, 5)2h -bi temem 
memory, IBM color graphics card and a GPIB interface board supplied with the 91DVS 
software. Two different software packages are provided with the 91DVS, DVSS0 and 
DVS25. The functions of both programs are similar, but the DVS50 1s installed at NPS 
because it offers an automatic compare feature and supports the tri-state control fea- 
tures. 

This section will include the capabilities and limitations of the DVS50 program, 
the menus required for operation, and a description of the two data files necessary to 


provide input to the DVSS0. 
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2. DVS50 Capabilities and Limitations 

The DVS50 program can support up to three DAS 9100 mainframes and 
Table 9 on page 41 lists the DAS 9100 modules that are supported by DVS50. While 
the DVS50 can support up to 192 pattern generation channels, all pattern generator 
modules must reside on the same DAS 9100 mainframe. The acquisition modules may 
be in any of the three DAS 9100 units but, if both the 91A08 and 91A32 modules are 
used, they must not be mixed in the same DAS 9100. Additionally, if a 91A08 module 
is used, one must be installed in slot six of the DAS 9100. 


Table 9. DVS50 MODULE SUPPORT 







An additional limitation is that the clock rate for the pattern generator and the 
data acquisition modules miust be clocked at the same rate. The acquisition module are 
@leened externally by the master clock of the 91S16 or the 91S32 module. 

3. DVS50 Input Programs 

There are two user generated data files necessarv to set-up the DVS50 for test- 
Mererest prooram file, .src . and the test pattern file, “.das’°. The test program file 
Specifies the test sequence, tinung, threshold and power supplv definitions. Figure 13 
on page 43 was the test program used for NPS CORNSS, and it will be examined to 11- 
lustrate the details of the “.srce” program. The kev word PROGRAM must start the 
“sre” program with the name of the program following this key word. The asterisk, “*”. 
indicates that the remainder of the 80 column line 1s ignored. This is used to section the 
program and to provide comments within the program to increase clarity of the pro- 
gram. The next section is headed by the kev word PINDEF and it identifies pin names, 
pin number assignments on the fabricated chip and the DVS50 attributes for that pin. 
The following attributes are supported by DVSS50: 

e PAT--pattern generator output channel 


e TRI--tristable pattern generator output channel 


e ACQ--data acquisition channel up to 25MHz 
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e FAST--data acquisition channel up to lOOMHz 
e CLkK--pattern generator clock output 


e PS--power supply output that is further defined in the PSDEF section 


As a matter of course the “ACQ” attribute is attached to as manv of the input channels 
as possible to monitor the input patterns. The end of each section is the key word 
EN 

The TIM{EDEF section sets the pattern and acquisition clock. Remember, that 
in the DVS50 the two clocks must be equal, so the program allows only the “PAT” input 
and that can vary from 40ns to Sms. The THRESHOLD section sets up the threshold 
voltage value. TTL is a predefined threshold voltage of +1.5V but variable voltages can 
be assigned ranging for -2v to 5v. Notice that the MOS option of -10.0V to +20.0V can. 
not be used in the DVS50. The PSDEF section details the values in mV and mA for 
voltages and current respectively. The ground connection of the DUT must be defined 
as 0 mV. Figure 13 on page 43 does not include a DATADEF section because the pat- 
tern sequences are defined in the ”.das” file. All “.src” programs must end with BEGIN: 
and ENDS to control the DAS 9100"ester 

The “.das” file for NPS CORNSS is listed in Figure 14 on page 44. The first line 
is the name of the program. The second and third lines are any two integers. These lines 
are used in the test result program that will be discussed below. Line 4 specifies the 
number of pins that DVS50 needs to generate patterns for. The pin names are then 
listed in rows that correspond with the pattern sequence in the respective columns. For 
example, the input channel PADIN will always have a pattern specified bv column one 
of the pattern sequence and CLO’s pattern will be located in column 24. An EOF at the 
end of the program indicates the end of the pattern. 

The test result file “.AQI” is in the same format as the ”.das” file except that only 
acquisiuon channels are reported. The clock rates for the pattern generator and data 
acquisition modules are included in lines two and three respectively. This file can be 
used to compare against another file transferred from the simulator output to validate 
the output vectors. 

This method of designating patterns and data acquisition parameters 1s much 
easier and quicker that using the DAS 9100 keyboard. A translator program, 
MOS2DAS, was written to generate the “.das”, “.src”, and the “.sim” files from the re- 


sults of the MOSSIM II simulation. This translator will be discussed in the next chap- 
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PROGRAM chip; 


PINDEF ; 

Vee V5 PS: 2; 
OUT2 ~ 27) Aco: 
OUD bb = (88), 
PADIN 4, PAT,ACQ; 
PADOUT : 5, ACQ; 
STSTOUT : 6, ACQ; 
IN16 7107 eral, ACO 
IN15 ee AL neo 
IN14 2:12, #PAT,ACQ; 
IN13 =113,0 - PAT ACO: 
LNT :14, PAT,ACQ; 
ie a ak 215, — PAT, ACO: 
IN1O “16, PAT, ACQ; 
INQ sy, ?PALTCACG: 
IN8 1s, PAT, ACQ; 
IN7 :19, PAT ACO; 
IN6 “20, PAT,ACQ; 
IN5 s2i,- PAT ACO: 
IN4 222, PAT/ACO; 
IN3 223, “PAT ACO; 
IN2 :24,  PAT,ACQ; 
IN1 "25, =PATHACO. 


DATACON :26, PAT ,ACQ; 
REFCON eee ge PAT,ACQ; 
MASKCON :28, PAT,ACQ; 
SPCON =30, PAT; 
TSTCON swale, PAT,ACQ; 
GND rie io rel Scene Ce 
BMSBOUT :36, ACQ; 
CUTGON 37. PAT,ACOQ; 


OUT5 : 30 ACOs 
OUT4 :39, ACQ; 
OUTS 7:40, ACQ; 

CLO 229, “PAT, ACO: 
END; 

TIMEDEF ; 


* Clockrate Pattern Generator. 
PAT : ns 100; 


END; 

THRESHOLD; 

* Threshold for Acquisition Module. 
ACQ : TTL; 

END; 

PSDEE: 

* Definition of Power Supply. 
12s mv 0; 

2 : mV 5000, mA 3000; 

END; 

BEGIN; 

ENDS 


Figure 13. NPS CORNS88 DVS50 .SRC File 
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Figure 14. 
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NPS CORNS88 DVS50 .DAS File 


+ 


4. DVS50 Menus 
Figure 15 on page 46, modified from Ref 20,p. 3-2, illustrates the system flow, 
from verifving the configuration file, compiling the test program, to running the tests 
and displaving the results. This flow is controlled by the use of menu driven screen dis- 
plavs. The first menu that the user encounters is the MAIN menu contains entries into 
all the of the first level menus that are listed below: 
e HELP 
¢ Compile Test Program 
e Restore Test Program 
e Information 
e Enter Test Menu 
e Update Configuration File 
e Display Test Data 
¢ Compare Data 


¢* Quit 


The screen cursor 1s controlled by the arrow kevs and a function or menu is called by 
positioning the cursor and pressing the “Enter” kev. The Update Configuration File is to 
entered first if the user needs information about the configuration or needs to modif¥ the 
current configuration due to a modification in the DAS 9100. This file mirrors the 
modules that are installed in the DAS 9100, power supply connections and controller 
specifications. This file is set-up to the DAS 9100 current configuration and usually does 
Mmemneed not be entered. 

Usually, the user will select the Compile Test Program as the first entry in the 
DVS50 menu. This menu uses the “.das ” and “.src” programs that were previously 
discussed and compiles a DVS control file and test pattern file to set-up the DAS 9100. 
This program also checks for errors in the “.das” and “.src” files and creates the channel 
specification list which describes the connections between the pattern generation and 
data acquisition pods and the DUT. Figure 16 on page 48 is the channel specification 
produced for NPS CORNS8 and the hook up of this specification will be discussed latter. 
The Restore Test Program uses the test files that were previously compiled in the Com- 
pile Test Program menu. 

After a test program file has been compiled the next step is to enter the Infor- 


mation menu. This menu allows the user to list or print the following: the test program, 
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Figure 15. DVS50 Processing Flow 
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the test record and the compare data. The principle purpose of entering this menu 1s to 
obtain a listing of the channel specifications created during the compilation of the test 
programs. 

Once the DAS probes have been connected to the DUT the Enter Test Menu 
is entered and “run test” 1s selected. This sets-up the DAS 9100, generates the sequence 
of patterns and the resulting acquired data from the DUT is uploaded to the PC. The 
“run test and compare’ entry in this menu will run the test and compare the acquired 
data to a reference file and report differences. Also, within this menu is the “enter device 
commands menu”. This sub-menu allows the user to send single commands to the de- 
vices supported by the 9IDVS. This function is used for debugging purposes and for 
experienced users and 1s covered 1n detail in the DVS user’s manual [Ref. 20,pp. 4-4,4-8]. 

The final DVS50 menu. and the most interesting to the user, is the Display Test 
Result. When entering this menu, the user is prompted for the names of two files, 
normally the recently acquired data file and a comparison file. Figure 18 on page 51 is 
an example of an observation window of the displaved file. A timing diagram of up to 
24 channels for the two files is overlaid on the display screen. Function keys are used 
to expand and compress the screen, move the observation window left of nght, and move 
the cursors left or right. The other useful features of this display are controlled by the 
command line. Channels can be listed, deleted, and inserted from this command line. 
A “scale” command sets the width of the observation window and the “time” command 
sets the beginning of the displaved window to the sequence specified. A “search” func- 
tion, also available from the command line, specifies a particular bit pattern for which 
to search. 

The primary disadvantage of this of this display is that a hard copv of the 
waveform timing diagram is unavailable, except through a print screen utilitv. This 
provides adequate results for analysis and demonstration but not enough resolution for 
inclusion in reports. 

The 91DVS program greatly reduces the time spent in setting up the DAS 9100, 
generating pattern sequences, and displaying test results. The capabilities provided by 
the 9IDVS are extensive enough for all but the most sophisticated user and it provides 
an excellent indoctrination into digital signal analysis. 

5. NPS CORNS8S8 
a. Set-up 
One aspect of testing that remains, regardless of whether the DAS 9100 or 


DVS50 techniques are used. is the connection of the DAS 9100 modules and probes to 
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xxx CHANNEL SPRCTEECALliION Liat. 4: 


ATTENTION : Connect the DAS-PODs to the pins of the DUT 
according to the following list. 
Take care - incorrect connections may cause 


permanent damage to the DAS-PODs or the DUT ! 


KKK KKK KKK KEKE KEKE KEKE KKK KK KEK KKK KKK KEK KKK KR KKK KEK KKK KEK KKK KKK KKK KK KK 


x Trigger channel(s): PG-POD ACQ-POD * 
" 3 Seale SD7 aa * 
KK KKK KKK KKK KKK KEKE KEK KKK KEK KEK KEKE KEKE KKK KKK KKK KEK KEKE KR KEKEKKRKEKKKEKKK 
x ACO clock channel(s): PG- POD EXTCLK-POD * 
x Pe-Chkea /G= Clk iia * 
KK KKK KK KK KKK KKK KKK KKK KK KKK KKK KKK KK KEK KKK KK KKK KK KKK KKKKKKEKKEKKEK 
* NR: NAME PINNUMBER POD(S) 

* PG ACQN ACQF other 

* aa ee Sy ih PS2 

* 2 Cur? ay io) BY otal 

* 3° OUR a)8) SD Sb 

x 4 PADIN 34 1B7-1 5D4-1 

* 5  PADOUT 35 5D3—1 

* 6 S¥oLreu 36 SD 2a 

* 7 IN16 40 e81B6-1 Spi 

* ee JWUbS, 1 -iBSs i SiO0-—1 

x 9 IN14 2. GBa ie s5e7 1 

x 1 Ogee ss 3. 4183-1) S5c6-1 

7 Seen le 4 Bla p5€5- 1 

hei Dee e 5 JB ieee = 

x 13 Vane 6: (1 BO ieee cs—i 

x 14 #x\9INI % lA/=ieSe2e 
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OPO” Aaa? 9° il AS ye SeOs 1 

x 17 #42x9XIN6 10 Rye tl 2s! ik 
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Figure 16. NPS CORN88 Channel Specifications 
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the pins on the DUT. Figure 16 on page 48 is the channel specification for NPS 
CORNSS and illustrates the power supply, pattern generation, and data acquisition 
DUT connections to be made. | 

The specified tngger channels for the pattern generator and data acquisition 
must be connected together to initialize and sync the two modules. The pattern gener- 
ator module is connected to the external clock pod to provide the clocking rate for the 
DUT. To facilitate the connections of the numerous probes to the DUT, a test board, 
Figure 17 on page 50, was built. Connections for the pattern generator and data ac- 
quisition probes were provided to the DUT bv quick release low insertion force con- 
nections. Additional connections were provided for power supplies and jumpers. The 
first connections to the test board are the grounds from the data acquisition pods and 
power and ground from the pattern generation pod. To keep line losses at a minimum 
the pattern generation probes have small amplifiers at the probe end called active pin 
drivers, or podlets. While this reduces line loss, it does generate heat at the podlet. To 
feauice heat build up in the podlet the power to the DUT should be left on for only the 
length of the test. Additional components are installed on the test jig to improve per- 
formance. The resistors eliminates possible podlet and DUT impedance mismatch. 
Gold plated connector pins are installed on the board to prevent corrosion within the 
podlet connector. 

b. Results 

The operational validation of NPS CORNSS8 was accomplished with the 
Seieereduced set of vectors that was used for design validation in MIOSSIM II. 
imeure 1S on page SI illustrates the results of the first test of the data register. 
Table 10 on page 52, test 1. sets the initial register conditions for this test. Notice that 
the resulting output 1s correct with a three clock phase propagation delay. The cursor 
marks the beginning of the correct output data. The ‘0’ is then rippled down the data 
register bits to validate all the data input register bits, and the expected BCD value of 
15 was observed at the outputs. 

The second test sequence of vectors, where the output results should go 
from 16-0 to test the combination adder circuitry, are illustrated in Figure 19 on page 
53 with the initial register values in test 2 of Table 10 on page 52. Notice that the out- 
put values for the 0 and 16 are the same, ‘00000! This error occurred in all 12 fabricated 
chips and indicated that the OUTS pin was always at a ‘0’ state. To determine whether 
a fabrication error or a Javout error was the cause of this malfunction, the MOSSIM II 


test sequence was run again on the final layout design of the chip. The test result for the 
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Table 10. NPS CORNS8S8 INITIAL REGISTER SET-UP 


TEST 
REF REG IN 
MASK REG IN 


BCD OLT DIGI Oa 10000, 16 
tee 


case of 16 matches resulted in the output “X0000' vice ‘10000’. Investigating further re- 









vealed that Vdd was not connected to the final multiplexer controlling OUTS. After this 
lavout was corrected, the output for 16 matches was ‘10000’ indicating that it indeed 
was a lavout problem not a fabrication problem that was discovered by the DAS 9100. 

The third sequence of vectors that tested the reference bank by rippling an 
error down the reference bank is illustrated in Figure 20 on page 54, with the initial 
register values in Table 11 on page 56 test 3 values. 

The masking tests started with no matches between the data and reference 
register as illustrated in test 4 of Table 11 on page 56. Figure 21 on page 55 demon- 
strates the effect of rippling two zeros, ‘00’, through the mask register to obtain an out- 
put of OO010". Additionally the odd values of masking combinations to further test the 
masking feature. The partitioning of the lavout design was verified by observing the 
serial output STSTOUT after activating the testcon line and also observing the MSB line 
from the combiner ‘adder. 

The previous test sequences verified the various register, the xnor circuitry, 
and the combiner adder for parallel operations. An additional test sequence needed to 
be run to validate the serial input functions of the chip. A different test program was 
Written to test these features. The rewriting of the test programs brought to light a 
limitation of this DAS 9100 configuration of only one 91A32 data acquisition module 
and one 91S32 pattern generator module installed. While it was relatively easy to gen- 
erate a new “.das” and “.src” file, this changed the pod assignments to the DUT and the 
original connections had to be modified. This modification was required due to the limit 
on the number of data acquisition channels that could be acquired. The original input 


files used all 31 data acquisition channels including the monitoring of the 16 parallel data 
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Figure 20. 
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Table 11. NPS CORN88 REFERENCE AND MASKING INITIAL REGISTER 
VALUES 
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input pins. The new program did not need to input a pattern or monitor the parallel 













input pins. Therefore, a new testing scheme had to be developed to generate patterns 
for the serial inputs and to monitor these serial inputs with data acquisition channels. 
While the modifications took only a short time, it would have been convenient to have 
an additional 91A32 installed so that the original program could have been written to 
support the testing of both parallel and serial data inputs. Figure 22 on page 57 illus- 
trates the serial data results. 

The test results validated the operational functionality of NPS CORNSS. 
Thev also illustrated that the DAS 9100 series tester, in conjunction with the 91DVS and 
DVS50 software, was capable of providing the necessary stimulus to test a full custom 
VLSI chip. 
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Figure 22. 


IV. MOS2DAS TRANSLATOR 


A. BACKGROUND 

The MOSSIM II simulation program functionally validates a circuit design by using 
test sequences to stimulate input pins and by monitoring the pins of interest. The test 
engineer must develop a set of vectors within this test sequence to validate the proper 
Operation of the design. When the design has been validated and the chip has been 
manufactured, the test engineer must again establish a test program for the manufac- 
tured chip. With the NPS digital analysis system, which includes the DAS 9100 
mainframe modular tester married to the DVS50 software, the test engineer inputs these 


itd 


test sequences through the DVS50 ”.das”, “.src”, and ”.sim” input files. 

An interactive translator that converts the test vectors that were defined aime 
MOSSIM II simulation program to the DVS50 input files provides three major advan- 
tages. The most obvious advantage of a translator is that it saves the test engineer's 
tume. MOSSIM II test sequences that were previously defined would be generated 
without the test engineer having to input the duplicate pattern sequences in DAS format. 
For a small test program the time savings would be insignificant. but as the test vector 
sequence scheme became longer and more complex, more time would be saved. The 
second benefit of using the translator is that the exact duplication of the MOSSIM II] 
test pattern sequences and results are ensured. This is important because the results 
of the fabricated chip should mirror the results of the MOSSIM II simulation. The third 
advantage in using the translator is that the test engineer does not need to learn how to 
produce the three DVS50 files. This is only a minor consideration because the input files 
are relatively straight forward and easy to learn. 

This chapter will discuss the capabilities and limitations of the MOS2DAS translator 
by examining the MOSSIM II commands that are supported by the translator. Addi- 
tionally, the shell program that was developed to control the file manipulation involved 
in the translation will be examined. The source code for the shell program and the 


Fortran source code for the MOS2DAS translator are included in Appendix B. 


B. MOS2DAS CAPABILITIES AND LIMITATIONS 
1. NLOSSIM IT Commands 
The MOS2DAS translator program generates three DVS50 input files from the 
MOSSIM I] “cps” and “.ntk” files: the test program file) “sre , the test patterment= 


@adeeeand the test result file, .sim’. [Phe “.cpv” file is used because it includes the out- 
puts from the pins of interest. Several different conventions and commands can not be 
translated to the DVSS50 input files because the DVSSO can not support them. When 
running the MIOSSIM II program that the user wants to translate to DVS50 format, all 


MOSSIM II software switches must be set to the default values as listed below: 


e ternary 0 
e sharing 0 
e static 0 
e restored 0 
¢ pseudo 0) 
e weaken 0 
e redundant ] 
e explain 0 
@ statistics 0 
e echo ] 
® case ] 


Additionally, all watch commands must be modified to watch every phase, with the 
“watch .*” command. This allows the program to report at the transition of every phase 
and more closely approximates what the DAS 9100 system will output. 

Several MOSSIM I] commands are used in the translation process, but some 
are not allowed. This 1s because the format of all the DVS50 input files requires that the 
pattern generation program must identify every channel prior to the first clock cvcle. 
Therefore, all the pins and vectors of interest must be defined prior to the first cycle of 
MiemetOSSINi Il program. Listed below are the MOSSIM II commands and their 
functions, as further defined in MOSSIM II user manual [Ref. 8.pp. 8-19] that are sup- 
ported by the WOS2DAS translator: 


e CLOCH--Defines the clocking scheme consisting of a set of clock nodes and a set 
of clock phases to be applied to these nodes. A MOSSIM II limitation is that, if 
more than one clock is defined, each clock must have the same number of phases 
in the sequence. For example, clock node ph1:0010 and clock node ph2:1000 are 
compatible non-overlapping clocks and are legal. The clock node ph1l:010 and 
clock node ph2:0010 combination is not legal because the sequence length 1s not 
the same. 


e VECTOR--This is used to assign one name to an ordered set of nodes. For exam- 
ple in Figure 23 on page 61 the vector ins contains all the parallel input nodes from 
inl-inl6. A mixture of input and output nodes are not allowed tn any one vector. 
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e Ji4TCH--This command allows the user to identify nodes of interest to be printed 
out at each cycle command. To closely align the output of the MOSSIM I] pro- 
gram and the results obtained by the DAS series from the manufactured chip the 
command “watch ;*” must be used to print the desired nodes after each phase of 
the clock. 


e SET--Sets the node to a specific binary value. Used to the generate the pattern 
generation sequence on that node or vector. Similar to the FORCE command ex- 
cept that the node or vector that is SET can be changed by the circuit operation 
to a new value. 


¢ FORCE--Sets the node to a specific binary value. This node will always be that 
value, no matter what the circuit design tries to do to that node. The UNFORCE 
is not supported because the DVSS5S0O program can not change node assignments 
after the first cycle command. 


¢ CYCLE--This causes the network to run for a specified number of cycles. The 
translator supports up to 20 cycles per command. 


¢ QUIT--This command indicates that the MOSSIM II simulation program is com- 
Dicte: 
While this may seem to be a limited number of MOSSIM II commands, the test pattern 
generation sequence can be long and quite complex. NPS CORN88 was tested with 
these conmmands and they proved to be acceptable. The remaining key words that in- 
voke MOSSIM I] commands are not translated and the entire line that starts with a 
command that 1s not supported 1s disregarded. MOS2DAS can translate three states 
allowed by the MOSSIM II program at each node to the two states that are supported 
by the DVS50 software. The MOSSIM II states ‘0’ and ‘I’ are translated to DVS30 
states ‘0’ and ‘I’, respectively. and the MOSSIM II “X’ state is translated toa 0. 
2. File Conversion Process 
The MOS2DAS translator creates the “.das”, “.src”, and “.sim” DVS50 input 
files. The “.das” file 1s used to define the input pattern generation channels. It identifies 
the input pin or input vector by searching the “.ntk” file to determine whether it is an 
input or output pin. The first pin name after the command vector is checked and, if that 
pin 1s an input pin, then the vector is an input vector. The input array of pin names 1s 
developed from the vector assignment and the set and force commands. Remember, all 
Input pins that are to be used in the DVS50 program must be defined prior to the first 
cycle statement. This is because at the first cycle statement the array of input pin names 
Is sequentially listed to the ”.das” file, with one pin name in each row. Figure 24 on page 
62 is an example of a “.das” file. Each of the input pins is presented to the user by the 
interactive translator program. The user must be able to determine whether the input 


pin should be used for the translation and if the pin should also be monitored. The 
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>»read CR chip.ntk 
#1 
1386 nodes, 2939 transistors, O blocks 
> 
>initialize 
mevock clk:010 
mector 1ns inl in2 in3 in4 ind in6 in7y in8 in9 
ieOomihiae dines ais ana ans and 6 
>»vector control datacon maskcon refcon tstcon 
>»vector misc spcon outcon 
Peeector OUtLS Outs out4 out3 outZ2 outl 
>»vector outl padout ststout bmsbout 
»watch /* outs outl 
>»watch /* ins clk 
» 
>comment load reference data 
meorce 1ns:llIITI1TIIII111111 
Marorce control: 1lLOO0O0 
Prorce padin:1 
mise: i 
1 
Suess U0000NeuEL: 100 ans: lita) clk:0 
Sacs OOmOO, outl=100 ans:LIlIIi eid elk:1 
Sis OOO0O ole 100 onset atid clk:0 





Figure 23. NPS CORNS88 MOSSIM II Simulation Program 


monitoring of the input pin will enable the user to display the input pattern during the 
display of the test results. 

Once the pin names have been defined, the values assigned to each input pin 
name are determined bv examining the force or set command for the vector or input pin 
defined. These values are also stored in an array of input values and, when the cycle 
command is recognized, the input pattern array is listed to the “.das” file as one row. 
The onlv remaining value to define in the “.das” file is the clock. The clock pins are 
handled by the DVS50 program as just another set of input pins. For each cvcle of the 
network the translator produces the same number of input patterns as there are phases 
ietnesclock. For example, if there is a three phase clock, the “.das” file produces three 
rows of binarv data for each cycle of the network. The pin names assigned to the 
clocking scheme are added to the input pin list directed to the ”.das” file and the clock 


phase value is appended to the row of input values. 


61 


DATACON 

MASKCON 

REFCON 

TSTCON 

SPCON 

OQUTCON 

CLO 

PULID TTT eee OO aie 
pt pHi Op ps Ui Ws i RD ea IO OO} 1 
LITRATO oars 





Figure 24. MOS2DAS ”.das” File 


The remaining inputs to the “.das” file are the first four hnes of the input file. 
The first row of the file is the program name and that 1s obtained from the interactive 
translator program. The second and third row of the “.das” file are any two integers. 
The fourth row is the number of pins in the input array in the ”.das” file. 

The “.sim” file is used to compare the output of the MOSSIM II simulator with 
the output from the DAS 9100 test svstem, ”.AQI”. The pin names defined in the ”.sim” 
file, as noted in the example of Figure 25 on page 64, are derived from the data acqui- 
sition assignments requested in the interactive translator program. Each of these pins 
in the “.src” program that have the attribute of “ACQ” assigned will be hsted to the 


“sim” file. When the pin names have been identified, the translator will search both the 


Input pin values using the set and force kev words and the output line of the simulator. 
Each line of output will list a row of binary values to the ”.sim” file. Except for lines two 
and three, the first four lines are similar to the “.das” file. Lines two and three in the 
“sim” file are timing data that was obtained from the ”.src” file. 

One difficulty with producing a ”.sim” file 1s that the MOSSIM ITI and DAS 9100 
system sample the output data at different times. DAS 9100 samples the data at the 
leading edge of the pattern generator clock, and MOSSIM II samples the data after a 
phase 1s complete. This sometimes results in a one phase delav for the output to be 
observed by the DAS 9100. Figure 26 on page 65 illustrates the sampling differences 
between the two programs and demonstrates the need to implement a one phase delay 
of the MOSSIM II output to align the data. NPS CORNS88 is an example of this output 
misalignment. To properly align the two output files the MOS2DAS translator is able 
to install a one phase delay in reporting the MOSSIM II output. During the interactive 
program the user will be asked if a phase delay is required, with the default value of a 
delay inserted. If, on comparison of the outputs, it is determined that a phase delay 1s 
not required, then the user will run the MOS2DAS translator again asking for no delav. 

While the MOSSIM II program will identify syntax violations the MOS2DAS 
translation program will verify operational limitations imposed by the DAS 9100 module 
set up. The current configuration allows 31 input pins and the abilitv to acquire data 
on 31 pins of mterest. This is because one channel from the data acquisition module is 
connected to a channel on the pattern generation module to facilitate synchronous tim- 
ing between the two modules. The MOS2DAS translator will check the requested input. 
“PAT”, and output .°“ACQ”. pin names prior to listing the pin names to the files and 
verify that the maximum number of input and output pins have not been exceeded. If 
the input or output pin count exceeds the limit, the user is prompted with an error 
miessage from the translator. This feature of the MOS2DAS program 1s easily modified 
when the module configuration of the DAS 9100 tester changes. 

As mentioned earlier, the “.src” test program file supplies the DVS50 program 
with the pin assignments, assigns an attribute to each pin identified, sets up the defi- 
nition of clock rates, determines the voltage threshold value for the circuit, and indicates 
the specifications for the power supply. This ”.src” input file, Figure 27 on page 66, 1s 
generated bv an interactive part of the MOS2DAS translator program. The program 
lists all the pins defined in the MOSSIM II simulation program and asks the user to pick 
an attribute and list the actual pin number on the fabricated chip. The output pins that 


were identified in the MMOSSIM II program will automatically be assigned the attribute 
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Figure 25. MOS2DAS ”.sim” File 


of “ACQ", if monitoring is desired, and the input pins will be assigned “PAT” with an 
option of also assigning the attribute of “ACQ” to these pins. It is wise to monitor each 
pattern generator input line to display the pattern being generated. The power supply 
pins are not included in the MOSSIM II program and the user will be prompted to 
provide the names, pin assignment and supply voltages. All other inputs required from 


the user are requested for interactively with the valid options provided. When the “src” 
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DAS 9100 | 

CLOCK | 
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Figure 26. DAS 9100 and MOSSIM Sampling Differences 


and “.das” input files are compiled by the DVS50 program a channel specification Hsting 
Eallebe generated to define the connections between the DAS 9100 and the DUT. The 
DVS50 has the ability to control tri-state channels but that capability 1s not supported 
by the \{OS2DAS translator. For further information on the tri-state function of the 


DVS50 consult the 91DVS user manual (Ref. 20.pp. 7-1,7- 4]. 


C. OPERATIONAL SHELL 

A UNIX C-Shell program. “MOS2DAS", was written to control the interactive file 
manipulation required by the translator. This executable file, along with the “mostral” 
lemitan program. is located in the LUW_TOOLS directory and ts executable by anv user 
that has access to the NIOSSIM II simulator. This UNIX C-Shell program. Figure 28 
on page 68. uses several UNIX utilities to manipulate the files: awk, grep, and diff. The 
user invokes the MOS2DAS translator by typing the following command at the UNIX 


Prompt: mos2das < .ntk> < .cpy>. 


PROGRAM chip; 


PINDEF ; 

AGS: ee TAS es, 
OUT2 ¢ 2, eke O- 
Our 23, @ac@. 
PADIN : 4, PAT,ACQ; 


PADOUT : 5, ACQ; 


IN16 7:10, PAT AGG: 
DNS sii, ~PAT ACO: 
IN14 :12, PAT,ACQ; 
IN13 2:13, PAT,ACQ; 
IN12 2:14,  PAT,ACQ; 
INil :15,. “PAT ACO: 
IN10 :16,  #PAT,ACQ; 
IN9 ¢<i7, PAT AGG: 
IN8 :18, PAT,ACQ; 
IN7 :19, PAT,ACQ; 
IN6 :20, PAT,ACQ; 
IN5 :21,  PAT,ACQ; 
IN4 <22, PALE,ACG: 
IN3 :23,  PAT,ACQ; 
IN2 :24, PAT,ACOQ; 
IN1 2:29,  #PAT,ACQ; 


DATACON :26, PAT,ACQ; 
REFCON :27, PAT,ACQ; 
MASKCON :28, PAT,ACQ; 
SPCON 7305. i. PAL. 
TSTCON | 2315). VPAT ACO: 
, GND :35, PS 1; 
BMSBOUT =36, ACO. 
OUTCON, :37,. PAT Aco: 


OUT5 2538. enc, 
OUT4 239 eACo- 
OUT3 :40, ACQ; 

CLO 1293 (PAL AG; 
END; 

TIMEDEF > 


* Clockrate Pattern Generator. 
PAT : ns 100; 


END; 

THRESHOLD ; 

* Threshold for AcquisiticneMogure: 
ACO : TIL; 

END; 

PSDEF ; 

* Definition of Power Supply. 
Ls mvV0; 

2: mV 5000, mA 3000; 

END; 

BEGIN; 

ENDS 


Figure 27. NIOS2DAS ” src” File 
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fethis is the beginning of all C Shell programs 

# this checks if there are two auguments 

mi( Stargvy !'= 2)then 
Beno "Msage: ntk2das <file.ntk> <file.cpy>" 
exit 

endif 


set ntkfile=sl 
Beno Sntkfile:r 
memo Sntkfile:r.cpy 
Poheck to see if the input file is a valid ntk file 
if(' -e $ntkfile ) then 
set ntkfile=$l1.ntk 


if( ! -e Sntkfile)then 

echo Cannot f£ind the file Sl or Si.ntk" 
exit 

endif 


endif 
#check to see if the input file is a valid mos copy file 
set mosfile=$2 


if(! -e Smosfile ) then 
set mosfile=Sl.cpy 


if( ! -e $mosfile)then 

echom Gannot find the fille Sil or Si.cpy" 
exit 

endif 


endif 


meeonvert the Liles to be used for the translator 
egrep i $ntkfile | awk '{print $2 }' > ntkin.dat 
egrep s Sntkfile >poutl 

egrep  Sntkfile >pout2 

@etk pPOutZ poutl > poutZ 

Beep > Ss’ pout2 | awk '{print $4}' > ntkout.dat 
mostral 

cp mos.das Sntkfile:r.das 

ee mos.src Sntkfile:r.src 

@eemos.cmp Sntkfile:r.sim 

rm mos.das mos.src mos.sim 

mrepeutcl pout2 ntkin.dat ntkout.dat 


Figure 28. NLOS2DAS C-Shell Operating Program 


The C-shell program then checks to insure that these files are valid files in the di- 


rectory and then renames the .“ntk” file to “transin.dat” for input to the “mostral” 
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translator. These utilities search the “.ntk” file that has been defined by the user and set 
up a file of input pin names and a file of output pin names. These file names are 
“ntkin.dat” and “ntkout.dat” respectively and are used by the “mostral” Fortran program 
as input files. Now that the input files have been specified for the “mostral” translator 
that executable program is called. The “mostral” program lists the “.das”, “.src”, and 
“sim” files into the temporary files “mos.das”, “mos.src”, and “mos.sim” respectively. 
These files are then copied to the original file name with the new file extension of ”.das”, 
“src”, and”.sim”. The temporary files are then erased and the translation process 1s 


complete. 
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VeeeIN CL SIONS 


A. SUMMARY 

This thesis validated the engineering methodology to produce a full custom, fully 
tested, VLSI chip from an original design using Naval Postgraduate School assets. 
During this validation process several elements of the design and testing phases were 
noteworthy. 

The first, and most important, element is the relationship between the design engi- 
neer and the test engineer. These functions, while at NPS, are often performed by the 
Same individual, but, in the testing of NPS CORNS$88, the circuit design engineer and the 
testing engineer Were not the same individual. This separation of responsibilities more 
closely duplicates industry's design and implementation of a full custom chip. When the 
responsibilities for producing a functional chip are shared, these key individuals must 
be involved from the initial design phase through the testing phase. Operating parame- 
ters and specifications must be defined for both the circuit design engineer and the test 
engineer. NPS CORNSS was a completed functional design with only an overview of 
the functions and capabilities provided. This made the testing strategy for the design 
difficult and could have lead to the development of invalid test routines. 

Two MOSSIM II test routines were developed for NPS CORNSS at the functional 
design validation level. One test vector sequence produced 2'° 16-bit vectors. to duphi- 
cate all possible input values, and the second test sequence produce a greatly reduced 
Sieset Oo! those vectors. Neither of these tests identified any problem with the circuit 
design. When the fabricated chip was tested with the DAS 9100, an error in an output 
pin was discovered. This reduced set of vectors was again run on the final design that 
was sent to fabrication. The error that appeared in the fabricated chip was duplicated in 
the circuit design simulation. This could only occur if some modification of NPS 
CORN88 has been done after the “final” testing. It is obvious that final testing must 
be accomplished after the final design is complete and just prior to sending the design 
mask to fabrication. 

The concept of partitioning the design to allow for additional observability within 
the circuit also proved useful. When the error was identified during the testing of the 
fabricated chip, the fault was isolated to the final adder section. This was done by ob- 


serving the outputs of the test register and the most significant bit from the combiner. 
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This was useful in the subsequent localizing of the error in the circuit design. While it 
i$ Important to increase the observabilitv of a VLSI chip, the primary limitation that is 
now associated with chip development is the limited number of pins in the fabrication 
package. When a standard frame package 1s used for fabrication, it 1s incumbent on the 
circuit designer and test engineer to utilize any extra pins to improve observability. 

The advantage of using MOSIS to produce a limited number of chips for a new 
circuit design is also obvious. Being able to produce a small number of VLSI chips to 
verifv the design and fabrication process greatly reduces the financial and schedule risk 
of large scale production. For a small expense, $1400, and a modest six week fabrication 
schedule. twelve prototvpe VLSI chips were produced. The error that was discovered 
during the testing of these fabricated chips would have been verv costly if this had been 
a large full scale production. 

The engineering methodology for the design and production of a full custom VLSI 
chip is well defined and adequate, but it requires knowledge of a CAD tool, MAGIC, 
the MOSSIM II simulator and the interface between the two major components. The 
flexibility that is gained bv using the MAGIC lavout editor and various simulator mod- 
els is over shadowed bv a silicon compilation system that controls the entire design and 
(eStIneS process. 

The DAS 9100 series tester as a stand-alone svstem is a capable and reliable digital 
analvsis tool. A broad-based knowledge of the capabilities and testing procedures are 
required before even the simplest test is performed. Another limitation of this svstem 
revolves around the kevboard entries that are required to set up the svstem and to store 
pattern sequences. This hmitation would be somewhat overcome if the tape recorder 
option was purchased to store this data so that the user would not have to reenter it 
after everv power down of the equipment. However, when the DAS 9100 series tester 
is married to the 91D VS, and the DVS50 program the system is user friendly and easy 
to use for even the most inexperienced test engineer. This digital analysis package 1s 
capable of generating comprehensive test pattern vectors and displaying the results for 
analvsis or comparison. The development of a translator, MOS2DAS, to convert 
MOSSIM II test vectors to the two programs needed by the DVS50 makes the test en- 


gineer job more efficient. 


B. RECOMMENDATIONS 
The current configuration of the DAS 9100 supports up to 32 data acquisition 


channels and 48 channels for pattern generation. This adequately tests a 40 pin VLSI 
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chip. An additional 91A32 data acquisition module should be purchased ($5,480) to im- 
prove the VLSI data acquisition to up to 64 pins. If the DAS 9100 is envisioned to 
Operate as a stand-alone tester, the addition of a tape recorder module would be con- 
sidered essential. If the DAS 9100 continues to operate with the DVS50 software the 
addition of a tape recorder is not necessary. The current power supply configuration for 
the DAS 9100 only supports one set of voltages. Because there are many power supplies 
at NPS that could easily be added to the DAS 9100 system the purchase of the power 
supply module is not recommended. 

Additional suggested research topics or projects are providing a translator from the 
GENESIL silicon compiler to DVS50 user programs and modifving the DSV50 software 
to allow the user to print a graphic display of digital waveform results. The current 
method 1s to capture and print the screen with a utility and that provides only moderate 


resolution. 


See bENEFITS 

The benefits of this research were four-fold. A very thorough understanding and 
appreciation of the methodology for producing a custom VLSI chip with the MAGIC 
layout was gained and presented to the reader. The digital test facilities at NPS were 
exanuned, discussed. and a testing methodology was presented. Being able to follow a 
MAGIC circuit design. NPS CORNSS., from design to testing of the fabricated chip was 
truly gratifving. 

This thesis developed two tools that are related to the NPS digital analvsis test fa- 
cilitv. The MOS2DAS translator will allow the digital test engineer to concentrate on 
the development of MMOSSIM II test vectors. The vectors that functionally validate the 
circuit design can be translated to the DVS50 input format, saving the test engineer time 
in testing the fabricated chip. Finally, the new user will find an introduction to the NPS 


digital test facilities in the tutorial provided in Appendix A. 
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APPENDIX A. NPS DIGITAL TEST FACILITY TUTORIAL 


A. PURPOSE 

The purpose of this tutorial is to provided an examination of the digital test facilities 
(DTF) at the Naval Postgraduate School (NPS). These test facilities at NPS include a 
digital analysis svstem, Tektronix DAS 9100 series tester, controlled by the device ver- 
ification software (DVS50) installed on a personal computer (PC). While the DAS 9100 
series tester can be operated as a stand-alone tester, the NPS configuration includes the 
link to the DVSSO software, and that will be the configuration discussed in this tutorial. 

This tutorial will provide an overview of the capabilities and limitations of the digital 
test facilities. Additionally, it will use the arithmetic logic unit (ALU1I81) as a vehicle 
to follow the testing methodology. Upon completion of this tutorial the user will be able 
to generate the input files for the DVS50, set up the device under test (DU Ty aaa 
manuever through the menus provided by the DVS50 program to compile and run a test, 


and to display the test results. 


B. CAPABILITIES AND LIMITATIONS 

As briefly discussed in the preceding section, the DTF is composed of many units. Each 
of these components provide some capabilities as well as some hmitations. The DTF 1s 
comprised of the Tektronix DAS 9100 series tester, DVS50 software on a PC Wiese 
power supply, and a test jig. The heart of the svstem is the DAS 9100 which performs 
the functions of data acquisition from and pattern generation to a DUT. The capabilities 
of the DAS 9100 are flexible, based on the modules that are installed in the DAS 
mainframe. The current configuration can support 32 channels of data acquisition and 
48 channels of pattern generation. The installed modules also set the timing capabihties. 
The current configuration can support a timing rate from 40nS to 5mS or a maximum 
rate of 25MHz. The DAS 9100 sets up the connectivity to the DUT and controls the 
clocking of the system. 

Equally important to the DTF is the DVS50 software, hosted on a personal com- 
puter collocated with the DAS 9100. This software is menu driven and uses the file 
generation file, “.src”, and the test pattern file, ”.das”, to control the DAS 9100. If the 
heart of the DTF is the DAS 9100, then the brains of the svstem is the DVS50 software. 
The two components are connected with a general purpose interface board. The 


limitation of using the DVSS50 software is the pattern generation clock and the data 


i 


acquisition clock are tied together and can not be run at separate speeds. Additionally, 
this clocking scheme takes one data acquisition channel and one pattern generation 
channel, so the current system is limited to 31 channels of data acquisition and 47 
channels of pattern generation. 

The power supply provides for 5 volts at 3 amperes. This restricts the current con- 
figuration to TTL logic levels, but the svstem can easily be configured to handle addi- 
tional power supplies if necessary. The test jig was designed and manufactured to make 
connecting the module probes to the chip easier. The test jig can handle up to a 40 pin 
chip, but the test jig could be expanded. In summary, the DTF offers an excellent tool 
to test digital chips and the capabilities and limitations are summarized below. 

eee ATA ACOUISITION CHANNELS 

eee A LIER N GENERATION CHANNELS 

e 40nS-5mS CLOCK RATE 

feel OR ECL LOGIC LEVEL 

een ieR SUPPLY ONLY 5 YOLTS AND 3 AMPERES 
fees! JIG SUPPORTS UP TO 40 PINS 


C. DVS30 INPUT FILES 

Mie two files that are required by the DVSSO software are the “.src” and the “.das” 
i@ileee the src file generates the configuration for the DAS 9100 and the ~.das” file 
contains a description of the test sequence pattern to be generated. The arithmetic logic 
unit model 181. ALUIS$1, will be used to demonstrate the functions of each of these files. 
The ALUISI performs 16 binary operations on two 4-bit words. Figure 29 on page 74 
was assembled from a TTL handbook [Ref. 21] and the addition of two 4-bit words will 
be the operation implemented. 

The “.srce” file generates the configuration to the DAS 9100 and the ”.das” file gen- 
erates the pattern to the DAS 9100. A third file that can be used by the DVS50 program 
ieee sim) file that can be used to compare the test results. These files must be created 
prior to entering the DVS50 test menu. This can be done in three ways, as outlined in 
Figure 30 on page 75. The first was is to generate the files on an editor the user is fa- 
miliar with and copy that file from a floppy disk to the working directory, c:\dvstest chip. 
The second method of producing a file is to create it on the VAX and use the NF I 
transfer method between the VAX and the PC. The third method 1s to access the editor 


after being in the working directory. The two editors that are available to that working 
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Connection Diagram Pin Designations 
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DESIGNATION PIN NOS. FUNCTION 


A3. A2, At, crs | We2l 2352 WORD A INPUTS 


| B3,82.81,80 | B2. 81, BO 18. 20. 22..1 WORD B INPUTS 


FUNCTION-SELECT 
INPUTS 


MODE CONTROL 
INPUT 
Fa.#2,F1,FO }13,11,10,8 | FUNCTION OUTPUTS 


CARRY PROPAGATE 
OUTPUT 

17 CARRY GENERATE 
OUTPUT 


NUMBER PACKAGE COUNT CARRY METHOD 


OF TYPICAL ADDITION TIMES ARITHMETIC/ LOOK AHEAD BETWEEN 
1 NONE 
2 RIPPLE 
3or 4 FULL LOOK-AHEAD 
5 to 16 FULL LOOK-AHEAD 


ACTIVE HIGH DATA 
SELECTION M®#H M = L; ARITHMETIC OPERATIONS 


LOGIC 


F=APLUS 1 
FeA+B F=(A+B)}PLUS 1 
FeA+B F = (A+B) PLUS 1 
F = MINUS 1 (2’s COMPL) | F = ZERO 
F=APLUS AB F = APLUS AB PLUS 1 
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F = AB MINUS 1 Fe AB ~ 
F =A PLUS AB F = APLUS AB PLUS 1 
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F = AB MINUS 1 FeAB 
F=APLUSA’° F=APLUSAPLUS 1 
F=(A+B)PLUSA F = (A+B) PLUS APLUS 1 
Fe (A+B) PLUSA F = (A+B) PLUS A PLUS 1 
F=AMINUS 1 Fea 
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FIGURE 1 7 
*Eech bit is shifted to the next more significant position. 


ALUISI1 Specifications 


directory are KEDIT and EDLIN. Whatever method is used to generate the files, they 


must be located on the working directory prior to entering the DVS50 program and they 


should be removed from the working directory after the testing is complete. 


C:\> 

C:\>CD GRAFPLUS 

C:\GRAFPLUS>GRAFPLUS 

1- PRINTER 

0 - SCREEN SET UP GRAFPLUS 
N - TEXT TO BE ABLE TO 
N - COLOR PRINT DISPLAY 
N - REVERSE 

Y - HORIZONTAL 

C:\GRAFPLUS>CD .. 

C:\> 


CA\>CD DVSTEST\CHIP 
CADVSTEST\CHIP> 


IF FILES LOCATED ON A DRIVE: 
copy e‘filenm # 


IF FILES ARE ON VAX: WHERE ARE THE 
USE NFT COMMANDS DVS50 INPUT FILES? 


IF NEED TO MAKE FILES: 
KEDIT FILENM SRC 


GO TO DVS50 
MENU 


CADVSTEST\CHIP>\DVS50\DVS50 





Figure 30. DOS Commands and File Directory Flow 


ive) este file that was used for testing the ALUISE chip 1s illustrated in Figure 31 
On page 77. This file will identifv the program name. pin names. pin number assign- 
ments. attribute assignments to the pins. clocking rates. power supply requirements, and 
required logic level. The illustrated file 1s straight forward, but some comments are in 
@ie@er 10 Clarify some of the options. The attributes that can be assigned to the pin. for 
fars)cXainple, are either the PAT“, “ACQ", or “PS”. The “PAT” attribute identifies that 
the pin will be an input pin and a pattern channel 1s reserved bv that name. The “ACQ’ 
attribute delineates a data acquisition channel. It 1s important to monitor. acquire, 
pattern generation channels to observe these channels on the displaved results. The “PS” 
attribute indicates that the pin is a power supply that will be defined latter in the 


“PSDEF” section. The other sections are self explanatory except for noting that the 


power supply parameters must be given in millivolts and milliamps. The ground must 
be defined as 0 mV for this section to be complete. 

The *.das” file defines the test sequence pattemi te be generated on the imput pms 
Figure 32 on page 78 illustrates the “.das” file that generated the patterns sequence for 
the ALUIS1 chip. The first line identifies the name of the chip and the next two lines 
can be any two integers. The fourth line indicates the number of input pins, and that 
is followed by each row containing a pin name. Each pin name corresponds to a pattern 
column that appears after the last pin name. For example, the first pin name is “B3” and 
the binary value in column one of the test sequence is assigned to that pin name. The 
last pin name will correspond to the last column in the test vector sequence. Values for 
the test sequences were developed to test several combinations of input values and to 
force the Various combinations of output results. 

The ”.sim” file in Figure 33 on page 79 is similar to the ”.das” file but it contains all 
the pin names that had the attribute of “ACQ” in the “.sre” file. The only difference 1s 
lines two and three which indicate the clocking rate of the circuit. The intention of this 
file is to prepare the expected results prior to the test and then compare the actual results 
to the calculated “.sim” file. This can be done durnng the display test feature oie 
DVS50. Once these files have been written the DVS50 menu driven program will be en- 


tered to! test taercinip, 


D. TEST PROGRAM COMPILATION 

The DVS50 1s a menu driven interactive program that Uses .das and ‘src filessee 
generate test patterns and control the DAS 9100 tester. The command to enter the 
DVSS0 program 1s: “dvs50.dvs50", illustrated in Figure 30 on page 75. The first menu 
that 1s encountered is the Main Menu and 1s illustrated in Figure 34 on page 81. To 
select a menu 1n this main menu move the cursor with the arrow keys and use <enter>. 
The Help menu will assist the new user in a brief summary of each menu item. The 
Update Configuration File controls the configuration, but the DVS50 is set up for the 
current configuration and this menu need not be entered. 

The first menu usually entered is the Compile Test Program menu. After selection 
of this entry the program will prompt the user for the “.src” and ”.das” files of the pro- 
gram to be run. The program will then compile these files and generate the DAS 9100 


‘ 


configuration and create a channel specification file. If the “.src” and “.das” files have 
been previously compiled and the test programs saved, then the test program can be re- 


stored by the Restore Test Program menu. 
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Figure 31. 


PROGRAM ALU181; 
x test of the arithmetic 


fegEesunit 74x18 I 


PINDEF ; 

* pin description 

BO ae jr PAL, ACO: 
AO oe PAL > ACO. 
S3 3, PAT, ACO: 
S2 4, PAT, ACO; 
Sl Swe PAT, * ACO: 
SO ben, EAL, ACO; 
CIN ime PAT, .-AC0: 
M Seal, SACO: 
FO 9, ACO; 

Fl LO eae: 

F2 IE, ae eie yy 

F3 12 eACO: 

AEQB 1452 VRCO- 

P plea GAC OF 

COUT Eo. ACO 

G ee ACF 

S35. L330 PAT Wence- 
A3 19, PAT, ACQ; 
Be 20, 2 PAT Aco: 
A2 21, )-PAT, 12860; 
SIL we). PAT eae - 
Al 2358 PAL wee eo- 
GND Ze VPS as: 

VDD way PS 2; 

END; 

TIMEDEF ; 

* Pattern Generator Clock Rate. 
PAT ns 200; 

END; 

MRE SHOmD ; 

* Threshold for Acquisition Modules. 
ACQ Ate Reg 

END; 

PSbEE ; 

* Definition of Power Supply. 
1 ity  O- 

2 : mV 5000, mA 3000; 
END; 

BEGIN; 

ENDS 


ALUIS1 ”.sre” File 


a 


OCOCOCOOTCIGGH 
00010001101001 
00100010101001 
01000100101001 
10001000101001 
LOOTOLII Ro On 
LICO1LILCCRee Cu 
LO0LTLOC Ie rCos 
LITT Lae 0 cet 





Figure 32. ALUI81 ”.das” File 


E. DOSE TUE 

Once the “.sim” and “.das” input test files have been compiled the information menu, 
Figure 34 on page &1, 1s entered to determine the channel specification definitions. It 
is recommended that the Printing item be selected first bv pressing enter when the cursor 
is at that position. This will toggle the printing from disabled to enabled. Then select 
the channel specification entry, and the results will be printed. If nothing happens. 
check to see if the printer cable is connected to the PC that 1s the host to DV SoOmsaie 
channel specification list gives the trigger, clock. pattern and data acquisition con- 


nections to the DUT. With the ALU1S1 channel specication, Figure 35 on pager: 


0000000010100110000 
0001000110100110010 
0010001010100110100 
HLESOCLOCLOLOOLIIO00 
1000100010100100000 
1001011110100100000 
1100110010100101000 
LOOMEOOLTOTOOTOGOTG 
LAM bP ne mne eho balane 





Figure 33. ALUISI ”.sim” File 


the layout of the test jig, Figure 37 on page 85, and the module lavout, Figure 38 on 
fece oo. the User can connect the modules to the DLT. 

Certain procedures need to be followed to ensure that damage is not done to the 
DUT or the DAS9100. Power will remain off during the entire set up procedure. The 
following steps are recommended for connecting the DUT, but they need not be ac- 
complished in the order stated: 

eee eRe THATTHE POWER SUPPLYAIS OFF **** 


¢ Connect the grounds for the modules: 


iy 


=» two pomona hook clips for data acquisition 

» two wires, black and green, from the pattern generator 

= one pomona hook clip from the external clock 

Connect power for the pattern generator module, red wire to +5V 


Install the two 12 pin resistor pads and install them next to the 40 pin easy out, 
with the wire connected to pin 12, gnd, and pin 24, Vdd. 


Connect power and ground to the chip. 

«» Connect a red wire from +5V to row D, pin 24 of the test jig. 

= Connect the capacitor between rows E and F of pin 24. 

«» The ground is connected with a small black jumper from row A to B on pin 12. 
Hook up the trigger. 


«= Pattern generator 1B STB-1, probe 8, ts connected to Acquisition channel 
a7 |e 


«= Use the jumper pin connections and ensure the reference side of the pattern 
generator connected to ground. 


Hook up External Clock. 


» Clk! (black wire), 7C-CLK1, to pattern generator, 1B-CLK4 jumper pin con- 
nections 


= connect any ground to the reference side of the pattern generation probe. 


Install the ALUI81 chip in the 40 pin connector. Ensure pins | and 24 are closest 
to the power supply connections. 


Connect the pattern generator probes to rows C and D of the appropriate pin 


Connect the data acquisition probes to A.B and E,F of the appropriate pins. En- 
Sure that the reference line 1s to the outside of the test j1g. 


F. RUNNING THE TEST 


Once the DUT 1s hooked up, turn the power on the DAS 9100 series tester. Then 


enter the Enter Test Menu illustrated in Figure 36 on page 84. Once in the Test menu 


select Run Test and then turn on the power supply when prompted by the program. 


The DVS50 program will download the channel specifications and the test pattern se- 
quences to the DAS 9100. The DAS 9100 wil then run the test on the DUT, ALUIS81, 
and then upload the acquired data to the DVS50 program. When this data transfer 1s 


complete, the DVS50 program will prompt the user to turn the power supply power off. 


This 1s necessary because the podlets, the small circuit boards at the end of the pattern 


generation probes, generate heat. 
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i} Hele 
Compile Test Froaram 
mestore Test Froqram 
Save Test Frogram 
Information 
Enter Test Menu 
Update Contiquration File 
Display Test Data 
Compare Data 


Quit 


keys to move cursor: use «ENTER? to select. 
FORDE RO RORD ER DADA ADE AAD ED EDERAL ARID IDES EDAD EL EREREDALEREDENERERERELEREREREREDEREREDEDEREREDERER ESA K SHER ED RENAE 
Main Menu 


FDEP ERED ESE VAD ERASE MER ELARRRAREDADEXERARAS RARER EXE ERARERER ADEE ER AREKES ARIK EREREREXALERERES BOTA ERED ERED ER ER ERED ERE! 


List Test Frogram 

ff List Channel Specification 
List Test Record 
List Compare Date 
Frinting (DISABLED) 


Return to the Main Menu 


27S tO move ctrsor: use «ENTER? to select. 
PERE A BCRP RRERERELERER ERED ELALELEREY EDEL AD RDELESRLARIL INES ER EDELAXER ERASERS RS RNAS AED RO ROR AR GAGE OEE ORO RS Rade aS dO KD 
Information Menu 
Test Frogram in Use : ALUI1S81 
SEVERED ELEM ERERERERER ALEX BLEDEL EDEL ERED ELEY EERE ER ADIL ELEDELEDED ROAST REG SEDASEE ARR SRA RAED ESAS EOE BORGER SAGO ROASTS 


Figure 34. DVS50 Main Menu 
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Once the power supply is turned off, return to the Main menu and then enter the 
Display Test Menu illustrated in Figure 36 on page 84. The program prompts for the 
",A01” and the ”.sim” files. The ”.AQ1” file contains the results of the test run by the 
DAS 9100. The ”.sim” file 1s developed by the user that includes the expected circuit 
results. If mo ~.sim’ file has been produced, then press thesspace Bamand <= enter ae 
indicated no additional file 1s to be compared. 

The waveform in Figure 39 on page 87 1s the display from the two 4-bit word ad- 
dition test of the ALUIS1. This display can contain 24 pin names and corresponding 
waveforms. The display window can be expanded, compressed, or moved to a different 
time in the test sequence. Figure 40 on page 88 lists the additional commands available 
to modifv this screen. The only wav to print out the displav 1s to invoke the print screen 
utility after the GRAFPLUS program has been installed. This installation must take 
place before entering the DVS50 Main menu. The commands for installing the 
GRAFPLUS utility are located in Figure 30 on page 75. Examunation of the displayed 


test results should indicate that the ALU181 performed as designed. 


G. CONCLUSIONS 

| The combination of the DAS 9100 and the DVSS0 program offer the user a powerful 
digital analysis tool. A chip with up to 40 pins with TTL logic can be tested by gener- 
ating test sequence patterns and acquiring data on 31 channels. The ALUI$1!1 demon- 
Strated the testing methodology and verified the steps necessary to conduct a test. 
Further information about the DVS50 program and the DAS 9100 series tester can be 
obtained from the 9IDVS User’s Manual [Ref. 20] and the DAS 9100 Operator's Man- 
Waleiveine leas 
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ATTENTION 


Connect the DAS-PODs to the pins of the DUT 
aGGenaing ce ene. following 11sec. 

Take care —- 
permanent damage to the DAS-PODs or the DUT ! 


incorrect connections may cause 
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Figure 35. 


Trigger channel(s): 


ACQ clock channel(s): 


PINNUMBER 
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PBS Clik 
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POD(S) 


ACON 
>DGer 
SID Il 
SPAS 
SPS Sk 
>DZe. 
SD: 
SbOa) 
2) O// sak 
266m 
Osim 
i) SaaS 
3) Gerard s 
2621 
Seale 
De Oak 
Seyi 
5B6-1 
Syetsim ll 
SBA 
Boa 
Si e\/4a ll 
Syeilie Ih. 


ALUI81 Channel Specifications 
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EXTCEK-POD 
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Figure 36. DVS50 Test Menu 
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Figure 38. Physical Location of the Modules 
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Figure 39. 
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APPENDIX B. MOSTRANS TRANSLATION PROGRAM 


This Appendix contains the “MOS2DAS’"shell program that controls the file con- 
version process for the “mostral” Fortran program that translates the MOSSIM I] 
program to DVS50 input programs. The “MOS2DAS” program requires the “.ntk” and 
“cpy’ files as input files and checks to see if they are valid files. The shell program then 
converts the “.ntk” file into an input and output pin list, NIKIN.DAT and 
NIKOUT.DAT. These files and the “.cpy” file renamed “CHECK” are used as input 
files for the “mostral” Fortran translator program. 

The “mostra!” program will read the “CHECK” program one line at a time and look 
for the kev MOSSIM II commands. This program also generates an interactive session 
with the user to define the desired pins, pin numbers, power supply definitions, and 
timing requirements. The translator will then examine the “CHECK” file and converts 
fete the \IOS.DAS’, “MOS.SRC’, and “MOS.SIM” DVS50 input files. 

The shell program then renames the translator files to the correct extensions to the 


“ntk” file name. The final action of the shell program is to erase all working files. 


A. TRANSLATOR SHELL PROGRAM 


# this is the beginning of all C Shell programs 
# this checks if there are two auguments 


if( S#argv != 2)then 
echo "usage: ntk2das <file.ntk> <file.cpy>' 
exit 

endif 


set ntkfile=$l 
##check to see if the input file is a valid ntk file 
if(! -e Sntkfile ) then 
set ntkfile=Sl.ntk 
if( ! ce Sntkfile)then 
echo "cannot find the file $1 or $1.ntk" 
exit 
endif 
endif 


##check to see if the input file is a valid mos copy file 
set mosfile=$2 
if(! -e Smosfile ) then 


set mosfile=$2. cpy 
if( ! -e Smosfile)then 
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echo “cannot find the file $2.05 o25cu.. 
exit 
endif 

endif 


# convert the files to be used for the translator 
egrep i Sntkfile awk '[print $2 ]' > NTKIN. DAT 
egrep s Sntkfile >poutl 

egrep _ Sntkfile >pout2 

diff pout2 pout ie sour. 

egrep '> s' pout3 awk ‘[print $4]' > NTKOUT. DAT 
cp Smosfile CHECK 

mostral 

cp MOS. DAS Sntkfile: r.das 

cp MOS. SR@ssntktile: = sre 

cp MOS.CMP Sntkfile: r.sim 

rm MOS.CMP MOS.SRC MOS. DAS CHECK 

rm poutl pout2 pout3 NTKIN. DAT NTKOUT. DAT 
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B. TRANSLATOR SOURCE PROGRAM 


CcCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC 


CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 


PROGRAM 
ENPOIS: 


OUTPUTS: 


PURPOSE: 


LIMITATIONS: 


wereieraeve TO CHANGE THE MAX NUMBER OF DATA ACQUISTION CHANNELS 


MOSTRANS 
NTKIN. DAT 


INPUT PINS 


NTKOUT. DAT OUTPUT PINS 


CHECK 

MOS. DAS 
MOS. o LM 
MOS. SRC 


TRANSLATE THE 
TWORNTK “Finis 


MAX NUMBER OF 
MAX NUMBER OF 
MAX NUMBER OF 
MAX NUMBER OF 


MOSSIM II 


ory Foie 


MOS std ll GRY PILE, CHEEKS SAND 


INTO THE THREE DVS50 FILES 


DATA ACQUISITION CHANNELS 
PATTERN GENERATION CHANNELS 
REPEDI  TMiVvEeor CLES 

POWEK SUPPLIES 


MAX PIN NAME LENGTH 


CHANGE MAXACQ IN SUBROUTINE SRC 


Wier TO CHANGE THE MAX NUMBER OF PATTERN GENERATION 


CHANNELS CHANGE MAXPAT IN SUBROUTINE SRC 


oul 
47 
20 

9 
10 


CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 


CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC 


CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC 


CC 
CC 
CC 


CC 


ARRAY 


NTKINPIN(40) 
NTKOUTPIN( 40) 
MOSINVEC( 20) 
MOSOUTVEC( 20) 
VPOSIN( 20) 
VPOSTRT( 20) 
DASINPIN(40) 
DASOUTPIN( 40) 
CHECK(8) 
ALINE(80) 


INPUT PIN NAMES FROM <NTK FILE 
OULLUT Pie vNAvrs st hOM- NUK PILE 


DESCRIPTION 


INPUT VECTOR NAMES FROM MOSSIM FILE 


OUTPUT VECTOR NAMES FROM MOSSIM FILE 


POINTER TO ENTRY INTO MOSINVEC 


POINTER LOSE Ni RY INO MOSOULVEC 


INPUT PIN NAMES TO .DAS 
OUTPUT PIN NAMES TO . DAS 
HOLDS MOSSIM KEY WORDS 


HOLDS COMPLE IRmRINE FROM MOSSIM FILE 


CC 


CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC 


INTEGER I,FSTCHAR, LASTCHAR , IVNUMIN, IVNUMOUT , IVPOSIN, IVPOSOUT 
PmeeER VFOSIN(20),VPOSTRI( 20) ,CLKSZ,FSTCYCLE ,CYCLENM,FINCNT 


INTEGER NTKIN,NTKOUT, IVWATCH ,WPOSTRT( 40) 
INTEGER VPOSTOP( 20) , IWAT ,WPOSTOP(40) ,SIMCNT, DASCNT , FSTDEL 
INTEGER CLKCNT,DASINCNT 
CHARACTER*80 SIMLINE , DASLINE , COMLINE , BLANK80 


CHARACTER*24 WORD, BLANK24 , TEMPW,CLOCKNM( 10) ,CLOCKVA( 10) 
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5 


C 
60 
70 


80 


90 


100 


C 


CHARACTER*24 CLKNUM,TCLKVAL 

CHARACTER"40 DASIN,PDASIN, DASOUT 

CHARACTER*10 INPUT ,TENBLNK , WATPIN( 80) 

CHARACTER*1 OWATVAL(40) , DWATVAL(40) 

CHARACTER*10 MOSINVEC( 20) ,MOSOUTVEC( 20) , WWATCH( 40) 

CHARACTER*10 NTKINPIN(40) ,NTKOUTPIN(40) , DASINPIN( 40) , DASOUTPIN( 40) 
CHARACTER*10 SIMNM(40) ,DASNM(40) 

CHARACTER*2 CYCVAL(20) 

CHARACTER*1 VCOMLINE( 80) , WATVAL(40) , DELAY 

CHARACTER*1 ALINE(80) , BLANK 


DATA CYCVAL/'1','2','3', 4°55, © 37 5 ComeoEee 10) 00 ciel oemunreen 
O13 5°04), 15, 16°, 17) pee ene, 

DATA BLANK24/' ry 

DATA BLANK/' '/ 

DATA BLANK80/' | 


OPEN( UNIT=10, ERR=950,STATUS='OLD' , FILE=' CHECK’ ) 
OPEN( UNIT=11, ERR=950, STATUS='OLD' , FILE='NTKIN. DAT' ) 
OPEN( UNIT=12 , ERR=950, STATUS='OLD' , FILE='NTKOUT. DAT’ ) 
OPEN( UNIT=13, ERR=951,STATUS='NEW' , FILE=' MOS. DAS' ) 
OPEN( UNIT=14 , ERR=951, STATUS='NEW' , FILE='MOS. CMP’ ) 
OPEN( UNIT=15 , ERR=951,STATUS='NEW' , FILE='MOS. SRC' ) 


WORD=BLANK24 

INT=0 

FSTCYCLE=0 

PINLONG=0 

NMDEL=0 

DO 5 I=1,40 
DASINPIN( I )=TENBLNK 
NTKINPIN( I )=TENBLNK 
NTKOUTPIN( I )=TENBLNK 

CONTINUE 

IVNUMIN=0 

IVPOS IN=0 

IVNUMOUT=0 

IVPOSOUT=0 

FSTDEL=0 

IWAT=0 

OPEN AND READ THE NTK FILES THAT HAVE THE INPUT AND OUTPUT PINS 

READ( 11,60,END=70)(NTKINPIN( I) , 1=1,40) 

FORMAT( A10) 

NTKIN=I 

CLOSE( 11, ERR=950) 

READ( 12, 80,END=90)(NTKOUTPIN(1) ,I=1,40) 

FORMAT(A10) 

NTKOUT=I 

CLOSE(12,ERR=950) 


FSTCHAR=0 
INT=INT+1 
LASTCHAR=0 


READS IN A LINE FROM THE MOSFILE TO CONVERT 
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EO 
CC 


CCC 
400 


410 


420 


425 


460 


465 


CC 
500 


READ(10,110,END=950)ALINE 

FORMAT( 80A1) 

LOOKS FOR KEY MOSSIM II COMMANDS 

CALL NXTWORD( ALINE , FSTCHAR, LASTCHAR ,WORD) 
IF(WORD. EQ. '>VECTOR'.OR. WORD. EQ. '>vector')GOTO 400 
IFC WORD. EQ. '>FORCE'.OR. WORD. EQ. '>force')GOTO 600 
IF(WORD. EQ. '>WATCH'.OR. WORD. EQ. '>watch')GOTO 500 
IF(WORD. EQ. '>CLOCK'.OR. WORD. EQ. '>clock')GOTO 700 
IF(WORD. EQ. '>CYCLE'.OR. WORD. EQ. '>cycle')GOTO 750 
IF(WORD. EQ. '>QUIT' .OR. WORD. EQ. '>quit')GOTO 999 
GOTO 190 


VECTOR HANDLING AREA 

TEMPW=BLANK24 

CALL NXTWORD( ALINE, FSTCHAR , LASTCHAR , WORD ) 
TEMPW=WORD 

CALL TQ GET NEXT PIN NAME 

CALL NXTWORD( ALINE , FSTCHAR , LASTCHAR , WORD ) 
CHECK TO SEE IF PIN WAS INPUT OR OUTPUT PIN 
AND THAT WILL DETERMINE WHICH VECTOR TO FILL 


DO 410 I=1,40 
IFCWORD .EQ. NTKINPINCI))GO TO 420 
IFCWORD .EQ. NTKOUTPIN(I))GO TO 460 
CONTINUE 
PRINT *,'ERROR IN PIN FILE’ 
GOTO 3250 


IVNUMIN=IVNUMIN+1 

MOSINVEC( IVNUMIN)=TEMPW 

IVPOS IN=IVPOSIN+1 

VPOSINC IVNUMIN)=IVPOSIN 

DAS INPIN( IVPOSIN)=WORD 

CALL NXTWORD( ALINE , FSTCHAR , LASTCHAR , WORD) 

IF(WORD .NE. 'NOWORD' )THEN 
IVPOS IN=IVPOSIN+1 
GOTO 425 

ENDIF 

GOTO 100 

IVNUMOUT=IVNUMOUT+1 

MOSOUTVEC( IVNUMOUT )=TEMPW 

IVPOSOUT=IVPOSOUT+1 

VPOSTRT( IVNUMOUT )=I VPOSOUT 

DASOUTPIN( IVPOSOUT )=WORD 

CALL NXTWORD( ALINE, FSTCHAR , LASTCHAR , WORD) 

IF(WORD .NE. '‘NOWORD' )THEN 
IVPOSOUT=IVPOSOUT+1 
GOTO 465 

ENDIF 

VPOSTOP( IVNUMOUT )=IVPOSOUT 

GOTO 100 


THIS AREA IS THE WATCH SECTION 


CALL NXTWORD( ALINE, FSTCHAR , LASTCHAR , WORD) 
IF(WORD .EQ. 'NOWORD')GOTO 100 


1s 


505 


ok, 


514 


Sys: 


D2Zo 


CC 
CC 
CC 
CC 
CC 
CC 


600 


CC 
CC 


620 


DO 505 I=1,IVNUMIN 
IF(WORD .EQ. MOSINVEC(I))GOTO 500 
DO 510 J=1,NTKIN 
IF(WORD .EQ. NTKINPIN(J))GOTO 500 
DO 515 I=1,IVNUMOUT 
IF(WORD .EQ. MOSOUTVEC(1I))THEN 
I VWATCH=IVWATCH+1 
IWAT=IWATH1 
VWATCH( IVWATCH)=WORD 
WPOSTRT( IVWATCH)=IWAT 
DO 514 J=VPOSTRT(1I) ,VPOSTOP( I) 
WATPIN( IWAT)=DASOUTPIN( J) 
IWAT=IWAT+1 
CONTINUE 
IWAT=IWAT-1 
WPOSTOP( IVWATCH)=IWAT 
GOTO 500 
ENDIF 
CONTINUE 


THIS WILL CHECK IF THE OUTPIN HAS BEEN USED IN A VECTOR TO PREVENT 
DUPLICATION OF PINS 


DO 516 I=1,IVPOSOUT 
IF( WORD. EQ. DASOUTPIN(CI))GOTO 500 
CONTINUE 


THIS AREA WILL CHECK TO SEE IF YOU WANT TO WATCH AN OUTPUT PIN 
NOT IN A VECTOR 


DO 3s2Z0e Se NThOUL 
IFQWORD; EQ. NTKOURPIN( I) ) THEN 
IWAT=IWAT+1 
WATPIN( IWAT )=WORD 
COTU 2500 
ENDIF 
CONTINUE 
GOTO 500 


THIS AREA IS THE FORCE ACTION AREA 
TWO THINGS CAN HAPPEN WHEN A FORCE COMMAND IS FOUND 
1. THE FORCE IS ON A VECTOR OR 
2, ,1HE FORCE 1S ON A SINGER Pin 
A. HAS THE PIN BEEN IDENTIFIED BERORE 
By .NEWeP UN 10 BEVEORGED 


CALL NXTWORD( ALINE, FSTCHAR , LASTCHAR, WORD) 
NXTWORD IS EITHER A VECTOR NAME OR A INPUT PIN NAME 
CHECKING FOR VECTOR NAME 
DO 620 I=1,IVNUMIN-1 
IF(WORD .EQ. MOSINVEC(I))THEN 
CALL NXTWORD( ALINE, FSTCHAR, LASTCHAR , WORD) 
DASIN( VPOSIN( I): (VPOSIN( I+1)-1))=WORD( 1: LASTCHAR-FSTCHAR+1) 
GOTO 100 
ENDIF 
CONTINUE 
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CC 
CC 


630 


CC 


CC 


700 


CC 


750 


USyS) 


1753 


we 
ee 


754 


IF(WORD .EQ. MOSINVEC( IVNUMIN) ) THEN 
CALL NXTWORD( ALINE , FSTCHAR , LASTCHAR , WORD) 
DASIN( VPOSIN( IVNUMIN): VPOSIN( IVNUMIN) +LASTCHAR-FSTCHAR )= 
WORD( 1: LASTCHAR-FSTCHAR#+1 ) 
GOTO 100 
END TE 


FORCE A PIN THAT IS NOT ASSOCIATED WITH A VECTOR 
CHECK TO SEE IF THAT PIN HAD BEEN IDENTIFIED IN A VECTOR STATEMENT 
DO 630 I=1,IVPOSIN 
IF(DASINPIN(I) .EQ. WORD)THEN 
CALL NXTWORD( ALINE , FSTCHAR , LASTCHAR , WORD) 
DASIN(I: 1) = WORD(1: 1) 
GOTO 100 
ENDIF 
CONTINUE 


NEW INPUT PIN IDENTIFIED PUT INTO ARRAY AND GET ASSOCIATED VALUE 
IVPOSIN=IVPOSIN+1 

DASINPINC IVPOSIN)=WORD 

CALL NXTWORD( ALINE, FSTCHAR , LASTCHAR , WORD ) 

DASINC IVPOSIN: IVPOSIN)=WORD( 1: 1) 

GOTO 100 


vevevs CLOCK vvex%r 

CLOCK AREA WILL ESTABLISH VALUES FOR CLOCK AND CLOCKSIZE 
CALL NXTWORD( ALINE , FSTCHAR, LASTCHAR, WORD) 

IF(WORD .EQ. 'NOWORD')GOTO 100 

CLKCNT=CLKCNT+1 

CLOCKNM( CLKCNT )=WORD 

CALL NXTWORD( ALINE , FSTCHAR , LASTCHAR, WORD) 

CLOCKVA( CLKCNT )=WORD 

CLKSZ=LASTCHAR-FSTCHAR+1 

GOTO 700 


veveve CYCLE wiv 

CYCLE AREA WILL INSERT CLOCK AND OUTPUT DAS LINE 
CALL NXTWORD( ALINE, FSTCHAR , LASTCHAR , WORD) 
CLKNUM=WORD 

FINCNT=IVPOSIN 

DAS INCNT=F INCNT+CLKCNT 

PDAS IN=DASIN 

Or i753 JJ=1 ,CGLKCNT 

DAS INPIN( FINCNT+JJ )=CLOCKNM( JJ) 

CONTINUE 


Titeptnom CIME CYCLE 1S CALLED INPUT PINS ARE DUMPED TO MOS. DAS 
AND THE COMBINATION OF INPUT AND WATCH PINS ARE DUMPED TO MOS. CMP 


IF(FSTCYCLE .EQ. 0)THEN 
CALL SRC(WATPIN, IWAT,DASINPIN, DASINCNT ,SIMNM,SIMCNT, 
DASNM , DASCNT, DELAY) 

WRITE( 13, 754)(DASNM(1) , I=1, DASCNT) 

FORMAT(A10) 


2 


Vy) 


760 


900 
chou 
JCZ 


920 


930 


FOS 
766 


1767 


WRITE(14,757)(SIMNM(I),I=1,SIMCNT) 
FORMAT(A10) 
FSTCYCLE=1 
ENDIF 
DO 760 I=1,20 
IF(CLKNUM .EQ. CYCVAL(1I))CYCLENM=I 
DO 780 J=1,CYCLENM 


DO 770 III=1,CLKSZ 
FSTCHAR=0 
LASTCHAR=0 
GOTO FILL AREA TO FILL NEXT LINE WITH SIM OUT DATA 
READ(10,901,END=950 )ALINE 
FORMAT( 80A1) 
CALL NXTWORD(C ALINE, FSTCHAR , LASTCHAR, WORD) 
LOOK FOR OUTPUT WATCH VECTOR TO MATCH 
IF(WORD .EQ. '‘NOWORD' )GOTO 763 
DO 930 I=1, IVWATCH 

IFCWORD .EQ. VWATCH(1))THEN 

CALL NXTWORD(C ALINE , FSTCHAR, LASTCHAR, WORD) 
K=1 
DO 920 JJ=WPOSTRT( 1) ,WPOSTOP( 1) 
WATVAL( JJ)=WORDCK: K) 
K=K+1 
CONTINUE 

GOTO 902 

ENDIF 
CONTINUE 


OUTPUT FPIN FOUND IN SIMULATOR OUTPUT LINE 
DO 940 JJ=1,IWAT 
IF( WORD. EQ. WATPIN( JJ) ) THEN 
CALL NXTWORD( ALINE , FSTCHAR , LASTCHAR, WORD) 
WATVAL( JJ)=WORD( 1: 1) 
GOTO 902 
ENDIF 
CONTINUE 


Gone 2902 
DOV1763 JIJ=1 Clic 
TOLKVAL=ChOCn acon 
PDASIN( FINCNT+JJ: FINCNT+JJ)=TCLKVALC III: III) 
CONTINUE 
SIMLINE=BLANK80 
DASLINE=BLANK80 
COMBINE THE INPUT PINS AND WATCH PINS FOR COMPARE FILE 
DO 766 IL=1,DASCNT 
DO. 765 Jl=1 DAsaNGNe 
IF(DASNM(IL) . EQ. DASINPIN( JI) )DASLINEC IL: IL)=PDASIN( JI: JI) 
CONTINUE 
CONTINUE 
DO 1767. i=l DAscim 
IF(DASLINE( LL: LL) .NE: “2 )DASUINE@EIaEL)— 0. 
WRITE( 13,767 )DASLINE 
FORMAT( A80) 
DO 769 IL=1,SIMCNT 
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DO 768 JI=1,IWAT 
IF(DELAY .EQ. ‘'Y' .OR. DELAY .EQ. '‘y')THEN 
IF(FSTDEL .EQ. 0)THEN 
OWATVAL( JI)=WATVAL( JI) 
ELSE 
OWATVAL( JI )=DWATVAL( JI) 
ENDIF 
DWATVAL( JI )=WATVAL( JI) 
ELSE 
OWATVAL( JI )=WATVAL( JI) 
ENDIF 
IF(SIMNM(IL) .EQ. WATPIN(JI))THEN 
SIMLINE( IL: IL)=OWATVAL( JI) 


Conor i769 
ENDIF 
768 CONTINUE 
1709 DO 772 ILL=1,DASINCNT 


IFCSIMNMCIL) .EQ. DASINPINCILL))SIMLINECIL: IL)= 
* PDASINC ILL: ILL) 


ne CONTINUE 
769 CONTINUE 
FSTDEL=1 
Oeil 71, Li=1,SiMCNT 
1171 IF(SIMLINE(LL: LL) .NE. '1')SIMLINE(LL: LL)='0' 
WRITE(14,771)SIMLINE 
oa FORMAT( A80) 
770 CONTINUE 
780 CONTINUE 
GOTO 100 


CC THIS AREA IS WHERE THE OUTPUT VALUES ARE STORED IN THE OUTPUT 
CC VARIABLES OF DASOUTPIN 


950 PRINT *,' INPUT ERROR PROCESSED' 
GOTO 999 
951 PRINT *,'NEWFILE ERROR’ 


CLOSE( 13 ,ERR=999 ) 

CLOSE( 14, ERR=999) 

CLOSE( 15 ,ERR=999 ) 
399 Su0P 

END 


vi 
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CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 


PROGRAM: MOSTRANS 

SUBROUTINE: NXTWORD 

INPUTS: ALINE CHARACTER LINE OF DATA 
FSTCHAR FIRST CHARACTER POSITION OF LOOK AT 
LASTCHAR LAST CHARACTER POSITION PRIOR TO 

DELINEATOR 
OUTPUT: WORD WORD OF INTEREST 
PURE OSE: TO LOOK AT A CHARACTER STRING AND USING THE SPACE 


AND COLON DELINEATORS PARSE THE NEXT WORD 


CC 
CC 
CC 
CC 
CC 


CCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCCC 


200 


210 
226 


230 
240 


SUBROUTINE NXTWORD( ALINE ,FSTCHAR , LASTCHAR , WORD) 
INTEGER FSTCHAR, LASTCHAR , ZEROCH 
CHARACTER*1 ALINE( 80) , BLANK , COLON 
CHARACTER*24 WORD, BLANK24 
DATA BLANK/' '/,BLANK24/' iP 
DATA COLON/': '/ 
F STCHAR=LASTCHAR+1 
ZEROCH=0 
WORD=BLANK24 
DO 200 I=FSTCHAR, 80 
IF(ALINE(I) .EQ. BLANK .OR. ALINE(I) .EQ. COLON)THEN 
GOTO 200 
ELSE 
IF(ZEROCH .EQ. 0)FSTCHAR=I 
ZEROCH=1 
ENDIF 
CONTINUE 
IF(ZEROCH .EQ. 0)THEN 
WORD='NOWORD ' 
GOTO 240 
ENDIF 


DO 210 J=FSTCHAR, 80 
IFCALINECJ) .EQ. BLANK | OR] ALINECS) © EO > Ceney auEN 
LASTCHAR=J- 1 
GOTO 220 
ENDIF 
CONTINUE 
TI=1 
DO 230 K=FSTCHAR, LASTCHAR 
WORD( II: II)=ALINE(K) 
II=lI+1 
CONTINUE 
END 
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CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 


PROGRAM: MOSTRANS 

SUBROUTINE: SRC 

NE UTS: WATPIN ARRAY OF WATCH PINS 
IWAT NUMBER OF WATCH PINS 


DASINPIN ARRAY OF INPUT PINS 
DAS INCNT NUMBER OF INPUT PINS 


OULPUTS: SIMNM ARRAY OF OUTPUT PINS 
SIMCNT NUMBER OF OUTPUT PINS 
DASNM ARRAY OF PATTERN PINS 
DASCNT NUMBER OF PATTERN PINS 
DELAY ONE PHASE DELAY 
PURPOSE: INTERACTIVE PROGRAM THAT WILL LIST THE INPUT AND 


WATCH PINS AND THE USER WILL PICK THE ONES THAT 


SHOULD BE TRANSLATED. A DELAY CAN ALIGN THE ". SIM" 


AND '. A01" DVSSO FILES. 


CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
CC 
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10 
CC 
CC 
CC 
CC 
CC 
CC 
CC 


201 


SUBROUTINE SRC(WATPIN, IWAT,DASINPIN, DASINCNT,SIMNM,SIMCNT, 


*DASNM , DASCNT , DELAY ) 


INTEGER I, IWAT,SRCPIN(40) ,DASINCNT,SIMCNT ,SRCCNT , DASCNT 
INTEGER PSCNT,PSAMP( 10) ,PSVOLT( 10) , TIMEVAL, MAXPAT , MAXACQ 
CHARACTER*10 WATPIN(5),SIMNM(40) ,DASINPIN(5) ,SRCNM(40) 
CHARACTER*10 DASNM( 40), TENBLNK , PSNAME , CHIPNM 

CHARACTER*3 ATTA(40) 

CHARACTER*4 ATTB(40) 

CHARACTER*1 APUN(40) , PATMON , ACQMON, DELAY 

DATA TENBLNK/' a 


MAXPAT=47 

MAXACO=31 

DASCNT=0 

SRCCNT=0 

S IMCNT=0 

Hoel 1=1 40 

DASNM( I )=TENBLNK 

S IMNM( I )=TENBLNK 

SRCNM( I )=TENBLNK 

eA = : 

AGEs 1)=" 

APUN(I)=' ' 

CONTINUE 

THIS STARTS THE DATA ACQUISITION SECTION 

THE USER WILL BE GIVEN THE MOSSIM II WATCH PINS 
AND HE WILL DECIDE WHETHER TO USE THE PIN AND GIVE THE 
PIN NUMBER 


SRCNM ARRAY HOLDS PINS FOR THE .SRC FILE 

SIMNM ARRAY HOLDS PINS FOR THE .SIM FILE 

SRCCNT , SIMCNT COUNTS NUMBER OF PINS IN EACH ARRAY 
WRITE( 6,201) 


FORMAT(1X,'WHAT IS THE NAME OF YOUR FILE?',/, 


*1X,'EX. CHIP **NO EXTENSION REQUIRED ‘'‘) 


oo 


READ(5 ,208)CHIPNM 

208  FORMAT(A10) 
WRITE( 15 ,209)CHIPNM 

209 FORMAT( 'PROGRAM’ ,1X,A10,/,'* 5/, * 4/, PINDER = 
WRITE(6,11) 

isl FORMAT( 1X, ‘THERE ARE A MAXIMUM OF 31 DATA ACQUISITION, (MONITOR),' 
*,/,' AND 31 PATTERN GENERATION CHANNELS FOR THIS DAS 9100 AND' 
*,/,' DVS50 SOFTWARE CONFIGURATION’ ) 
DO 50, I=iawAT 


WRITE(6,15 )WATPIN(I) 

1G FORMAT(1X,'DO YOU WANT TO MONITOR ',A10,'?') 
READ(5 , 18)ACQMON 

18 FORMAT(A1) 


IF(ACQMON .EQ. 'N' .OR. ACQMON .EQ. 'n')GOTO 50 
SRCCNT=SRCCNT+1 

SIMCNT=SIMCNT+1 

IF(SIMCNT .GE. 32)GOTO 401 

SRCNM( SRCCNT)=WATPIN(I) 

SIMNM( SIMCNT)=WATPIN( I) 

ATMACSRCENT)=" ACO: 

APUNCSRCCNT)='; ' 


White Co a20) 

20 FORMAT(1X,'WHAT IS THE PIN NUMBER? ') 
READ(5,30)SRCPINCSRCCNT) 

30 FORMAT(I2) 


50 CONTINUE 


CC THIS AREA WILL INPUT THE PATTERN PINS 
CC AND WILL ASK THE USER IF THE PIN IS TO BE INCLUDED 
CC AND IF MONITORING IS DESIRED 


DO 100, I=1,DASINCNT 
WRITE(6,60)DASINPIN(I) 


60 FORMAT(1X,'DO YOU WANT A PATTERN ON PIN ',A10,'?') 
READ(5 ,65 ) PATMON 
65 FORMAT( Al) 


IF(PATMON .EQ. 'N' .OR. PATMON .EQ. ‘n')GOTO 100 
SRCCNT=SRCCNT+1 

DASCNT=DASCNT+1 

IF(DASCNT .GE. 32)GOTO 403 

SRCGNM( SRCCNT )=DASINPIN(I) 

DASNM( DASCNT )=DASINPIN(I) 

ATTACSROONT)=— EAm, 


WRITE( 6,70) 

70 FORMAT(1X,'WHAT IS THE PIN NUMBER? ') 
READ(5,75)SRCPIN( SRCCNT) 

75 FORMAT( 12) 
WRITE(6,80) 

80 FORMAT(1X,'DO YOU ALSO WANT TO MONITOR THIS PIN? ') 
READ(5 ,85 )ACQMON 

85 FORMAT(A1) 


IF(ACQMON .EQ. 'N' .OR. ACQMON .EQ. 'n')THEN 
APUN(SRCCNT)='; ' 
GOTO 100 
ELSE 
SIMCNT=SIMCNT+1 


100 


100 


CC 


105 
110 


ES 


120 


1) 


130 


i) 


140 
200 


ZO 
CC 


220) 


225 


IF(SIMCNT .GE. 32)GOTO 401 
SIMNM( SIMCNT)=DASINPIN(1) 
APUN(CSRCCNT)=' 7, ' 
ATTB( SRCCNT)=' ACQ; ' 

ENDIF 


CONTINUE 


THIS IS THE POWER SUPPLY SECTION 
PSCNT=0 

WRITE(6,110) 

FORMAT(1X,'THE USER WILL DEFINE THE POWER SUPPLY PARAMETERS',/,1X, 
*'IN THIS SECTION. WHAT IS A PIN NAME FOR THE POWER SUPPLY?',/, 
*' EX. VDD OR GND ***TYPE DONE FOR PIN NAME WHEN FINISHED ',/) 


READ(5,115)PSNAME 

FORMAT( A10) 

IF(PSNAME .EQ. 'DONE' .OR. PSNAME .EQ. ‘done')GOTO 200 
PSCNT=PSCNT+1 
SRCCNT=SRCCNT+1 

SRCNM( SRCCNT )=PSNAME 
WRITE(6,70) 
READ(5,120)SRCPIN(SRCCNT) 
FORMAT(1I2) 

PMESCSROCNT)='PS ' 

IF(PSCNT .EQ. 1)APUN(SRCCNT) 
IF(PSCNT .EQ. 2)APUN(SRCCNT) 
IF(PSCNT .EQ. 3)APUN(SRCCNT) 
IF(PSCNT .EQ. 4)APUN(SRCCNT) 
IF(PSCNT .EQ. 5)APUN( SRCCNT) 
IF(PSCNT .EQ. 6)APUN( SRCCNT) 
IF(PSCNT .EQ. 7)APUN(SRCCNT) 
IF(PSCNT .EQ. 8)APUN(SRCCNT) 
IF(PSCNT .EQ. 9)APUN(SRCCNT) 
ATTB(SRCCNT)=' ; 

WRITE( 6,225) 

FORMAT( 1X, 'WHAT VOLTAGE, IN mV, IS ON THIS PIN?’ ,/,1X, 
*'EX 5000 "NOTE GND MUST HAVE 0 ') 
READ(5,130)PSVOLT( PSCNT) 

FORMAT(I5) 

WRITE(6,135) 

FORMAT( 1X, 'WHAT AMPERAGE, IN mA, IS ON THIS PIN?',/,1X, 
*'EX 3000 ***NOTE GND MUST HAVE 0 ') 

READ( 5,140) PSAMP( PSCNT) 

FORMAT(CI5) 

GOTO 105 

WRITE(15,210)(SRCNM(1),SRCPIN(I) ,ATTA(I),APUN(I), 
*ATTBC( I), I=1,SRCCNT) 

BORMAMCAIO, : ,12,', ,2x,A3,A1,A4) 

THIS SECTION WILL INPUT THE TIMING REQUIREMENTS 

WRITE( 15,220) 

BORMAR@ END: './,'*',/,'TIMEDEP: 4/, * 4/ 
* | '% CLOCKRATE PATTERN GENERATOR. ',/,'*') 

WRITE( 6,225) 

FORMAT( 1X,'WHAT CLOCKING RATE, IN nS, DO YOU WANT FOR THE' 
aciRGUMl? ./, FROM 40nS TO 5000nS “EX. 100 ~~) 


WOmonIAM EWN re 


nk utd bd nh ue ut 


101 


Z30 
Zo 
Zo2 
225 


240 


202 


205 
206 


410 


415 


401 


402 


403 
404 


500 


READ(5,230)TIMEVAL 

FORMAT(I4) 

WRITE( 13,231)CHIPNM, TIMEVAL, TIMEVAL, DASCNT 
FORMATCA10ny = 144)/ hae) 

WRITE( 14, 232) CHIPNM, TIMEVAL, TIMEVAL, SIMCNT 

FORMATCA10%/, 145/145. a) 

WRITE( 15, 235 )TIMEVAL 

FORMAT( “(PAT ens “Sia 

WRITE( 15,240) 

FORMAT( ‘END; ',/,'%*',/, | THRESHOLD; ' Hes ie 
vel as THRESHOLD FOR ACQUISITION MODULE. year ,/; ACO > Tiiamee.. 
*' END; 

WRITE( 15,202) 

FORMAT @ Shy op DE ye 22 oy ena DEFINITION OF THE' 
* "POWER SUPPLY. ',/) 

WRITE(15, 205)(1, ee PSAMP(I) , 1=1,PSCNT) 

FORMAT( 11, urn woe mA PeeSs tty 

WRITE( 15 , 206) 

FORMATC( ' END yee hae 
WS” 3 ee ee GEN: ,/, ENDS") 

WRITE(6,410) 

FORMAT( 1X, 'DO YOU WANT A ONE PHASE DELAY IN THE OUTPUT TO' 
*/,' ALIGN THE OUTPUT FILES FOR MOSSIM AND DAS 9100? °Y,N 
READ(5,415)DELAY 

FORMAT(A1) 

GOTO 500 

WRITE(6 ,402) 

FORMAT(1X,° %?e%: *ERROR*** YOU HAVE EXCEEDED THE NUMBER ' 
*' OF PINS TO MONITOR',/,' YOU MUST RUN THE TRANSLATOR AGAIN. ') 
GOTO 500 

WRITE(6,404) 

FORMAT( 1X, '******ERROR*3"* YOU HAVE EXCEEDED THE NUMBER', 
*' OF PINS FOR PATTERN',/,' GENERATION. YOU MUST RUN THE’, 
*' TRANSLATOR AGAIN. ') 


P 


END 
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APPENDIX C. VECTOR GENERATION PROGRAMS 


A. VECTOR SHELL PROGRAM 


iF 

#This program will take vectors in vectors. out 

#and input them to the MOSSIM II program crm 

#and then compare the results the MOSSIM II 

#program with a comvec.out and put the differences in 
#a file called difres.out 

+ 
echo 
echo "start time of the program was ''>difres. out 
date>>difres. out 

Seno 

rm -f mossim.nst mossim. bst 

eeho | 

echo Disregard the below comments from Mossim.' 
echo Be Patient. 

echo 

mossim << + 

seur crm 

yes 

Beur vectors. out 

q 

au 

edit CR_result. cpy<resmod. cmd>/dev/null 

echo 

echo "Only differences in the files are listed below. 3'' >> difres. out 

echo -n "If there are no differences your files are matched." >> difres. out 


ree 


echo ere 


monet -b CR_result. cpy comvec. out >> difres. out 
echo ‘end time is ‘'>>difres. out 
date>>difres. out 

else 
echo 
exit 
echo 
endif 


ttt 
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B. VECTOR GENERATION C SOURCE CODE 


/*This program will generate the number of 16-bit vectors that 
is requested by the user. These vectors are written to the 
vectors.out file. This program also computes the values for 
the output vector from the 16-bit correlator, NPS CORN88. 
These output vectors are located in the comvec.oout file. */ 


#include<stdio. h> 
4tinclude<math. h> 


float sam 

Eleatres. 

ait > j., eee 

unsigned int mask=1,vec,nout; 
int temp| 16l,cout) 5); 

int tl,rtime; 


main() 


FILE *fpl, *topem@): 
FILE *tp2)) fepeme. 
fpl=fopen("'vectors. out", w); 
fp2=fopen("'comvec. out'',"'w' ); 


printf("How large do you want the vector. n’); 
scanf(''%6d" ,&t1); 

/* sscant(arev| 1), Shc seri. 
fprintf(fpl, force control Ww aeem.): 
fprintt( tpl, toree select. 000 1). 
forines( tpl, forceumise: imas- 


for(i=0;2-el- i), 
vec=i; 
for( j=0; j<=15; j++) { 
if( vec&émask)temp[ j] =1; 
else temp[ j] =0; 
vec=vec>>]; 
} 
fprintt( tpl, forcemimes ss, 
for( k=15; k>=1;k--)§ 
fprintt( tpl, de, eemp| ie. 
} 


fprintt (tpl, 2am seen oler 
fprintfCtpl, evele une 


/* computes the compare vectors and outputs to comvec. out*/ 
rtime=20; 
for(i=0. 1b) i 
vec=i; 
rtime=rtimetl; 
nout=0; 
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POG =—0,1<— log itt) 
if(vec&mask) {temp[ j] =1; 
nout=nouttl; } 
else temp[ j] =0; 
vec=vec>>]; 


for( 1=0; 1<=4; 14+) { 
if(nout&mask)cout[ 1]=1; 
else cout[ 1] =0; 
nout=nout>>]1; 


if(rtime<=99) 
ip anne) Ad. tame): 
else 
Cpe rt pies cd get imejs 
foment od... ~Olts: .): 
for(1=4; 1>=0; 1--)f 
fp raiMtnenp ae ad cout) Ll): 
} 
pomimimneGoe. ins: 
for( k=15; k>=1; k--){ 
fpriner@Eepey cde templ iar 


fprintf(fp2,'%d n",temp|[ 0] ); 


rewind( fpl); 
rewind( fp2); 
tfelose( ipa): 
fclose(fp2); 


iN Ole: 
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